sunxi_can.h revision 1.1 1 1.1 bouyer /* $NetBSD: sunxi_can.h,v 1.1 2018/03/07 20:55:31 bouyer Exp $ */
2 1.1 bouyer
3 1.1 bouyer /*-
4 1.1 bouyer * Copyright (c) 2017,2018 The NetBSD Foundation, Inc.
5 1.1 bouyer * All rights reserved.
6 1.1 bouyer *
7 1.1 bouyer * This code is derived from software contributed to The NetBSD Foundation
8 1.1 bouyer * by Manuel Bouyer.
9 1.1 bouyer *
10 1.1 bouyer * Redistribution and use in source and binary forms, with or without
11 1.1 bouyer * modification, are permitted provided that the following conditions
12 1.1 bouyer * are met:
13 1.1 bouyer * 1. Redistributions of source code must retain the above copyright
14 1.1 bouyer * notice, this list of conditions and the following disclaimer.
15 1.1 bouyer * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 bouyer * notice, this list of conditions and the following disclaimer in the
17 1.1 bouyer * documentation and/or other materials provided with the distribution.
18 1.1 bouyer *
19 1.1 bouyer * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 bouyer * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 bouyer * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 bouyer * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 bouyer * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 bouyer * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 bouyer * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 bouyer * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 bouyer * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 bouyer * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 bouyer * POSSIBILITY OF SUCH DAMAGE.
30 1.1 bouyer */
31 1.1 bouyer
32 1.1 bouyer /* CAN mode select register */
33 1.1 bouyer #define SUNXI_CAN_MODSEL_REG 0x00
34 1.1 bouyer #define SUNXI_CAN_MODSEL_SLEEP __BIT(4)
35 1.1 bouyer #define SUNXI_CAN_MODSEL_ACP_FLT_MOD __BIT(3)
36 1.1 bouyer #define SUNXI_CAN_MODSEL_LB_MOD __BIT(2)
37 1.1 bouyer #define SUNXI_CAN_MODSEL_LST_ONLY __BIT(1)
38 1.1 bouyer #define SUNXI_CAN_MODSEL_RST __BIT(0)
39 1.1 bouyer
40 1.1 bouyer /* CAN command register */
41 1.1 bouyer #define SUNXI_CAN_CMD_REG 0x04
42 1.1 bouyer #define SUNXI_CAN_CMD_BUS_OFF __BIT(5)
43 1.1 bouyer #define SUNXI_CAN_CMD_SELF_REQ __BIT(4)
44 1.1 bouyer #define SUNXI_CAN_CMD_CLR_OR __BIT(3)
45 1.1 bouyer #define SUNXI_CAN_CMD_REL_RX_BUF __BIT(2)
46 1.1 bouyer #define SUNXI_CAN_CMD_ABT_REQ __BIT(1)
47 1.1 bouyer #define SUNXI_CAN_CMD_TANS_REQ __BIT(0)
48 1.1 bouyer
49 1.1 bouyer /* CAN status register */
50 1.1 bouyer #define SUNXI_CAN_STA_REG 0x08
51 1.1 bouyer #define SUNXI_CAN_STA_ERR_CODE __BITS(23,22)
52 1.1 bouyer #define SUNXI_CAN_STA_ERR_CODE_BIT 0
53 1.1 bouyer #define SUNXI_CAN_STA_ERR_CODE_FORM 1
54 1.1 bouyer #define SUNXI_CAN_STA_ERR_CODE_STUFF 2
55 1.1 bouyer #define SUNXI_CAN_STA_ERR_CODE_OTHER 3
56 1.1 bouyer #define SUNXI_CAN_STA_ERR_DIR _BIT(21)
57 1.1 bouyer #define SUNXI_CAN_STA_ERR_SEG_CODE __BITS(20,16)
58 1.1 bouyer #define SUNXI_CAN_STA_ARB_LOST __BITS(12,8)
59 1.1 bouyer #define SUNXI_CAN_STA_BUS __BIT(7)
60 1.1 bouyer #define SUNXI_CAN_STA_ERR __BIT(6)
61 1.1 bouyer #define SUNXI_CAN_STA_TX __BIT(5)
62 1.1 bouyer #define SUNXI_CAN_STA_RX __BIT(4)
63 1.1 bouyer #define SUNXI_CAN_STA_TX_OVER __BIT(3)
64 1.1 bouyer #define SUNXI_CAN_STA_TX_RDY __BIT(2)
65 1.1 bouyer #define SUNXI_CAN_STA_DATA_OR __BIT(1)
66 1.1 bouyer #define SUNXI_CAN_STA_RX_RDY __BIT(0)
67 1.1 bouyer
68 1.1 bouyer /* CAN interrupt register */
69 1.1 bouyer #define SUNXI_CAN_INT_REG 0x0c
70 1.1 bouyer #define SUNXI_CAN_INT_BERR __BIT(7)
71 1.1 bouyer #define SUNXI_CAN_INT_ARB_LOST __BIT(6)
72 1.1 bouyer #define SUNXI_CAN_INT_ERR_PASSIVE __BIT(5)
73 1.1 bouyer #define SUNXI_CAN_INT_WAKEUP __BIT(4)
74 1.1 bouyer #define SUNXI_CAN_INT_DATA_OR __BIT(3)
75 1.1 bouyer #define SUNXI_CAN_INT_ERR __BIT(2)
76 1.1 bouyer #define SUNXI_CAN_INT_TX_FLAG __BIT(1)
77 1.1 bouyer #define SUNXI_CAN_INT_RX_FLAG __BIT(0)
78 1.1 bouyer
79 1.1 bouyer /* CAN interrupt enable register */
80 1.1 bouyer #define SUNXI_CAN_INTE_REG 0x10
81 1.1 bouyer
82 1.1 bouyer /* CAN bus timing register */
83 1.1 bouyer #define SUNXI_CAN_BUS_TIME_REG 0x14
84 1.1 bouyer #define SUNXI_CAN_BUS_TIME_SAM __BIT(23)
85 1.1 bouyer #define SUNXI_CAN_BUS_TIME_PHSEG2 __BITS(22,20)
86 1.1 bouyer #define SUNXI_CAN_BUS_TIME_PHSEG1 __BITS(19,16)
87 1.1 bouyer #define SUNXI_CAN_BUS_TIME_SJW __BITS(15,14)
88 1.1 bouyer #define SUNXI_CAN_BUS_TIME_TQ_BRP __BITS(9,0)
89 1.1 bouyer
90 1.1 bouyer /* CAN tx error warning limit register */
91 1.1 bouyer #define SUNXI_CAN_EWL_REG 0x18
92 1.1 bouyer #define SUNXI_CAN_EWL_ERR_WRN_LMT __BITS(7,0)
93 1.1 bouyer
94 1.1 bouyer /* CAN error counter register */
95 1.1 bouyer #define SUNXI_CAN_REC_REG 0x1c
96 1.1 bouyer #define SUNXI_CAN_REC_RX_ERR_CNT __BITS(23,16)
97 1.1 bouyer #define SUNXI_CAN_REC_TX_ERR_CNT __BITS(7,0)
98 1.1 bouyer
99 1.1 bouyer /* CAN receive message register */
100 1.1 bouyer #define SUNXI_CAN_RMSGC_REG 0x20
101 1.1 bouyer #define SUNXI_CAN_RMSGC_RX_MSG_CNT __BITS(7,0)
102 1.1 bouyer
103 1.1 bouyer /* CAN receive buffer start address register */
104 1.1 bouyer #define SUNXI_CAN_RSADDR_REG 0x24
105 1.1 bouyer #define SUNXI_CAN_RSADDR_RX_BUF_SADDR __BITS(5,0)
106 1.1 bouyer
107 1.1 bouyer /* CAN rx/tx message buffer 0 register */
108 1.1 bouyer #define SUNXI_CAN_TXBUF0_REG 0x40
109 1.1 bouyer #define SUNXI_CAN_TXBUF0_EFF __BIT(7)
110 1.1 bouyer #define SUNXI_CAN_TXBUF0_RTR __BIT(6)
111 1.1 bouyer #define SUNXI_CAN_TXBUF0_DL __BITS(3,0)
112 1.1 bouyer
113 1.1 bouyer /* CAN rx/tx message buffer registers */
114 1.1 bouyer #define SUNXI_CAN_TXBUF1_REG 0x44
115 1.1 bouyer #define SUNXI_CAN_TXBUF2_REG 0x48
116 1.1 bouyer #define SUNXI_CAN_TXBUF3_REG 0x4c
117 1.1 bouyer #define SUNXI_CAN_TXBUF4_REG 0x50
118 1.1 bouyer #define SUNXI_CAN_TXBUF5_REG 0x54
119 1.1 bouyer #define SUNXI_CAN_TXBUF6_REG 0x58
120 1.1 bouyer #define SUNXI_CAN_TXBUF7_REG 0x5c
121 1.1 bouyer #define SUNXI_CAN_TXBUF8_REG 0x60
122 1.1 bouyer #define SUNXI_CAN_TXBUF9_REG 0x64
123 1.1 bouyer #define SUNXI_CAN_TXBUF10_REG 0x68
124 1.1 bouyer #define SUNXI_CAN_TXBUF11_REG 0x6c
125 1.1 bouyer #define SUNXI_CAN_TXBUF12_REG 0x70
126 1.1 bouyer
127 1.1 bouyer /* CAN acceptance code 0 register */
128 1.1 bouyer #define SUNXI_CAN_ACPC 0x40
129 1.1 bouyer
130 1.1 bouyer /* CAN acceptance mask 0 register */
131 1.1 bouyer #define SUNXI_CAN_ACPM 0x44
132 1.1 bouyer
133 1.1 bouyer /* CAN transmit buffer for read back registers */
134 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK0 0x180
135 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK1 0x184
136 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK2 0x188
137 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK3 0x18c
138 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK4 0x190
139 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK5 0x194
140 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK6 0x198
141 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK7 0x19c
142 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK8 0x1a0
143 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK9 0x1a4
144 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK10 0x1a8
145 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK11 0x1ac
146 1.1 bouyer #define SUNXI_CAN_RBUF_RBACK12 0x1b0
147