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