18 #ifndef INCLUDE_CAN_SJA1000_H_ 19 #define INCLUDE_CAN_SJA1000_H_ 22 #define SJA1000_MAP_SIZE 128 80 #define CAN_RANGE 0x20 125 #define CAN_SLEEP_MODE 0x10 126 #define CAN_ACC_FILT_MASK 0x08 127 #define CAN_SELF_TEST_MODE 0x04 128 #define CAN_LISTEN_ONLY_MODE 0x02 129 #define CAN_RESET_REQUEST 0x01 130 #define CAN_MODE_DEF CAN_ACC_FILT_MASK 160 #define CAN_ERROR_BUSOFF_INT_ENABLE (1<<7) 162 #define CAN_ARBITR_LOST_INT_ENABLE (1<<6) 164 #define CAN_ERROR_PASSIVE_INT_ENABLE (1<<5) 166 #define CAN_WAKEUP_INT_ENABLE (1<<4) 168 #define CAN_OVERRUN_INT_ENABLE (1<<3) 170 #define CAN_ERROR_INT_ENABLE (1<<2) 172 #define CAN_TRANSMIT_INT_ENABLE (1<<1) 174 #define CAN_RECEIVE_INT_ENABLE (1<<0) 253 #define CAN_GOTO_SLEEP (1<<4) 255 #define CAN_CLEAR_OVERRUN_STATUS (1<<3) 257 #define CAN_RELEASE_RECEIVE_BUFFER (1<<2) 259 #define CAN_ABORT_TRANSMISSION (1<<1) 261 #define CAN_TRANSMISSION_REQUEST (1<<0) 316 #define CAN_BUS_STATUS (1<<7) 318 #define CAN_ERROR_STATUS (1<<6) 320 #define CAN_TRANSMIT_STATUS (1<<5) 322 #define CAN_RECEIVE_STATUS (1<<4) 324 #define CAN_TRANSMISSION_COMPLETE_STATUS (1<<3) 326 #define CAN_TRANSMIT_BUFFER_ACCESS (1<<2) 328 #define CAN_DATA_OVERRUN (1<<1) 330 #define CAN_RECEIVE_BUFFER_STATUS (1<<0) 367 #define CAN_WAKEUP_INT (1<<4) 369 #define CAN_OVERRUN_INT (1<<3) 371 #define CAN_ERROR_INT (1<<2) 373 #define CAN_TRANSMIT_INT (1<<1) 375 #define CAN_RECEIVE_INT (1<<0) 405 #define CAN_OCTP1 (1<<7) 407 #define CAN_OCTN1 (1<<6) 409 #define CAN_OCPOL1 (1<<5) 411 #define CAN_OCTP0 (1<<4) 413 #define CAN_OCTN0 (1<<3) 415 #define CAN_OCPOL0 (1<<2) 417 #define CAN_OCMODE1 (1<<1) 419 #define CAN_OCMODE0 (1<<0) 439 #define CAN_MODE_BASICCAN (0x00) 440 #define CAN_MODE_PELICAN (0xC0) 444 #define CAN_MODE_CLK1 (0x07) 445 #define CAN_MODE_CLK2 (0x00) 448 #define CAN_MODE_CLK CAN_MODE_CLK2 458 # define CAN_RTR (1<<6) 463 #define CAN_TIM0_10K 49 464 #define CAN_TIM1_10K 0x1c 465 #define CAN_TIM0_20K 24 466 #define CAN_TIM1_20K 0x1c 467 #define CAN_TIM0_40K 0x89 468 #define CAN_TIM1_40K 0xEB 469 #define CAN_TIM0_50K 9 470 #define CAN_TIM1_50K 0x1c 471 #define CAN_TIM0_100K 4 472 #define CAN_TIM1_100K 0x1c 473 #define CAN_TIM0_125K 3 474 #define CAN_TIM1_125K 0x1c 475 #define CAN_TIM0_250K 1 476 #define CAN_TIM1_250K 0x1c 477 #define CAN_TIM0_500K 0 478 #define CAN_TIM1_500K 0x1c 479 #define CAN_TIM0_800K 0 480 #define CAN_TIM1_800K 0x16 481 #define CAN_TIM0_1000K 0 482 #define CAN_TIM1_1000K 0x14 490 #define MAX_CHANNELS 1 497 #define DBGprint(ms,ar) { } 500 #define DEBUG_TTY(n, args...) 501 extern unsigned int dbgMask;
535 #define MSG_ACTIVE (0) 537 #define MSG_RTR (1<<0) 538 #define MSG_OVR (1<<1) 539 #define MSG_EXT (1<<2) 540 #define MSG_SELF (1<<3) 541 #define MSG_PASSIVE (1<<4) 542 #define MSG_BUSOFF (1<<5) 543 #define MSG_WARNING (1<<6) 544 #define MSG_BOVR (1<<7) 547 #define MSG_ERR_MASK (MSG_OVR+MSG_PASSIVE+MSG_BUSOFF+MSG_BOVR+MSG_WARNING) 550 #define CAN_SFF_MASK 0x000007FFU 551 #define CAN_EFF_MASK 0x1FFFFFFFU 552 #define CANDRIVERERROR 0xFFFFFFFFul 557 #define LINUX_VERSION_CODE 1 558 #define KERNEL_VERSION(X,Y,Z) 0 559 typedef int irqreturn_t;
561 #define IRQ_HANDLED 1 562 #define IRQ_RETVAL(x) (x) 575 static inline unsigned char can_read_reg(
BYTE *addr)
577 volatile BYTE *preg = (
volatile BYTE*) (addr);
583 static inline void can_write_reg(
BYTE *addr,
BYTE value)
585 volatile BYTE *preg = (
volatile BYTE*) (addr);
593 static inline void can_set_reg(
BYTE *addr,
BYTE mask)
595 volatile BYTE *preg = (
volatile BYTE*) (addr);
603 static inline void can_reset_reg(
BYTE *addr,
BYTE mask)
605 volatile BYTE *preg = (
volatile BYTE *) (addr);
616 #define CANin(bd,adr) can_read_reg(&can_base_addr->adr) 617 #define CANout(bd,adr,v) can_write_reg(&can_base_addr->adr, v) 618 #define CANset(bd,adr,m) can_set_reg(&can_base_addr->adr, m) 619 #define CANreset(bd,adr,m) can_reset_reg(&can_base_addr->adr, m) unsigned int baud
Definition: sja1000.h:505
unsigned int error_warning_limit
Definition: sja1000.h:507
BYTE canxdata[8]
Definition: sja1000.h:41
BYTE cantim0
Definition: sja1000.h:63
unsigned int rx_errors
Definition: sja1000.h:508
BYTE canirq
Definition: sja1000.h:60
struct CanStatusPar CanStatusPar_t
BYTE frameinfo
Definition: sja1000.h:73
BYTE reserved3
Definition: sja1000.h:75
BYTE rxerror
Definition: sja1000.h:71
BYTE reserved2
Definition: sja1000.h:67
Definition: sja1000.h:504
unsigned int rx_buffer_size
Definition: sja1000.h:511
Definition: sja1000.h:523
BYTE canoutc
Definition: sja1000.h:65
struct frame::@2 extframe
unsigned int error_code
Definition: sja1000.h:510
BYTE errorcode
Definition: sja1000.h:69
BYTE canid3
Definition: sja1000.h:39
BYTE canid2
Definition: sja1000.h:38
BYTE cantest
Definition: sja1000.h:66
unsigned char BYTE
Definition: common.h:39
BYTE canid4
Definition: sja1000.h:40
BYTE txerror
Definition: sja1000.h:72
BYTE cantim1
Definition: sja1000.h:64
BYTE reserved1
Definition: sja1000.h:62
BYTE errorwarninglimit
Definition: sja1000.h:70
BYTE candata[8]
Definition: sja1000.h:46
BYTE canid1
Definition: sja1000.h:37
unsigned int tx_buffer_used
Definition: sja1000.h:514
BYTE canrxbufferadr
Definition: sja1000.h:76
struct canregs __attribute__((packed)) canregs_t
BYTE canstat
Definition: sja1000.h:59
canregs_t * can_base_addr
Definition: can_dev.cpp:22
BYTE cancmd
Definition: sja1000.h:58
Definition: sja1000.h:527
unsigned long retval
Definition: sja1000.h:515
unsigned int tx_buffer_size
Definition: sja1000.h:513
BYTE canirq_enable
Definition: sja1000.h:61
BYTE canclk
Definition: sja1000.h:77
BYTE canmode
Definition: sja1000.h:57
unsigned int tx_errors
Definition: sja1000.h:509
struct frame::@3 stdframe
unsigned int rx_buffer_used
Definition: sja1000.h:512
BYTE arbitrationlost
Definition: sja1000.h:68
Definition: sja1000.h:531
unsigned int status
Definition: sja1000.h:506