summaryrefslogtreecommitdiffstats
path: root/reg/usbotg.h
diff options
context:
space:
mode:
authorTomasz Kramkowski <tk@the-tk.com>2017-02-26 12:17:04 +0000
committerTomasz Kramkowski <tk@the-tk.com>2017-02-26 12:17:04 +0000
commit89d90cab84a112f342973878abb87311184460ac (patch)
treef9bdc0e849ecf9f2a22157e63249de0e458fe211 /reg/usbotg.h
parent5092828e34c2cd744e1af7463ad343f34e23cfb3 (diff)
downloadmk20dx256-89d90cab84a112f342973878abb87311184460ac.tar.gz
mk20dx256-89d90cab84a112f342973878abb87311184460ac.tar.xz
mk20dx256-89d90cab84a112f342973878abb87311184460ac.zip
reg/usbotg: Adhere to new style
Diffstat (limited to 'reg/usbotg.h')
-rw-r--r--reg/usbotg.h243
1 files changed, 137 insertions, 106 deletions
diff --git a/reg/usbotg.h b/reg/usbotg.h
index 56f00aa..1343581 100644
--- a/reg/usbotg.h
+++ b/reg/usbotg.h
@@ -3,40 +3,47 @@
#include "regdefs.h"
-#define USB0_PERID REG_8(0x40072000) /* Peripheral ID register */
-#define PERID_ID 0 /* Peripheral Identification */
-#define PERID_ID_M (uint8_t)(0x3F)
-
-#define USB0_IDCOMP REG_8(0x40072004) /* Peripheral ID Complement register */
-#define IDCOMP_NID 0 /* Ones complement of peripheral identification bits. */
-#define IDCOMP_NID_M (uint8_t)(0x3F)
-
-#define USB0_REV REG_8(0x40072008) /* Peripheral Revision register */
-#define REV_REV 0 /* Revision */
-#define REV_REV_M (uint8_t)(0xFF)
-
-#define USB0_ADDINFO REG_8(0x4007200C) /* Peripheral Additional Info register */
-#define ADDINFO_IRQNUM 3 /* Assigned Interrupt Request Number. */
-#define ADDINFO_IRQNUM_M (uint8_t)(BITS(5) << ADDINFO_IRQNUM)
-#define ADDINFO_IEHOST 0 /* Set if SIE is in host mode. */
-
-#define USB0_OTGISTAT REG_8(0x40072010) /* OTG Interrupt Status register */
-#define OTGISTAT_IDCHG 7 /* Set on change in the ID Signal from the USB connector. */
-#define OTGISTAT_ONEMSEC 6 /* Set on 1 ms timer expire. */
-#define OTGISTAT_LINE_STATE_CHG 5 /* Set when USB line state changes. */
+// Peripheral ID register
+#define USB0_PERID REG_8(0x40072000)
+#define PERID_ID 0 // Peripheral Identification
+#define PERID_ID_M REG_8_M(PERID_ID, 6)
+
+// Peripheral ID Complement register
+#define USB0_IDCOMP REG_8(0x40072004)
+#define IDCOMP_NID 0 // Ones complement of peripheral identification bits.
+#define IDCOMP_NID_M REG_8_M(IDCOMP_NID, 6)
+
+// Peripheral Revision register
+#define USB0_REV REG_8(0x40072008)
+#define REV_REV 0 // Revision
+#define REV_REV_M REG_8_M(REV_REV, 8)
+
+// Peripheral Additional Info register
+#define USB0_ADDINFO REG_8(0x4007200C)
+#define ADDINFO_IRQNUM 3 // Assigned Interrupt Request Number.
+#define ADDINFO_IRQNUM_M REG_8_M(ADDINFO_IRQNUM, 5)
+#define ADDINFO_IEHOST 0 // Set if SIE is in host mode.
+
+// OTG Interrupt Status register
+#define USB0_OTGISTAT REG_8(0x40072010)
+#define OTGISTAT_IDCHG 7 // Set on change in the ID Signal from the USB connector.
+#define OTGISTAT_ONEMSEC 6 // Set on 1 ms timer expire.
+#define OTGISTAT_LINE_STATE_CHG 5 // Set when USB line state changes.
#define OTGISTAT_SESSVLDCHG 3
#define OTGISTAT_B_SESS_CHG 2
#define OTGISTAT_AVBUSCHG 0
-#define USB0_OTGICR REG_8(0x40072014) /* OTG Interrupt Control Register */
-#define OTGICR_IDEN 7 /* ID Interrupt Enable */
-#define OTGICR_ONEMSECEN 6 /* One Millisecond Interrupt Enable */
-#define OTGICR_LINESTATEEN 5 /* Line State Change Interrupt Enable */
-#define OTGICR_SESSVLDEN 3 /* Session Valid Interrupt Enable */
-#define OTGICR_BSESSEN 2 /* B Session END Interrupt Enable */
-#define OTGICR_AVBUSEN 0 /* A VBUS Valid Interrupt Enable */
-
-#define USB0_OTGSTAT REG_8(0x40072018) /* OTG Status register */
+// OTG Interrupt Control Register
+#define USB0_OTGICR REG_8(0x40072014)
+#define OTGICR_IDEN 7 // ID Interrupt Enable
+#define OTGICR_ONEMSECEN 6 // One Millisecond Interrupt Enable
+#define OTGICR_LINESTATEEN 5 // Line State Change Interrupt Enable
+#define OTGICR_SESSVLDEN 3 // Session Valid Interrupt Enable
+#define OTGICR_BSESSEN 2 // B Session END Interrupt Enable
+#define OTGICR_AVBUSEN 0 // A VBUS Valid Interrupt Enable
+
+// OTG Status register
+#define USB0_OTGSTAT REG_8(0x40072018)
#define OTGSTAT_ID 7
#define OTGSTAT_ONEMSECEN 6
#define OTGSTAT_LINESTATESTABLE 5
@@ -44,15 +51,17 @@
#define OTGSTAT_BSESSEND 2
#define OTGSTAT_AVBUSVLD 0
-#define USB0_OTGCTL REG_8(0x4007201C) /* OTG Control register */
-#define OTGCTL_DPHIGH 7 /* D+ Data Line pullup resistor enable */
-#define OTGCTL_DPLOW 5 /* D+ Data Line pull-down resistor enable */
-#define OTGCTL_DMLOW 4 /* D– Data Line pull-down resistor enable */
-#define OTGCTL_OTGEN 2 /* On-The-Go pullup/pulldown resistor enable */
-
-#define USB0_ISTAT REG_8(0x40072080) /* Interrupt Status register */
-#define ISTAT_STALL 7 /* Stall Interrupt */
-#define ISTAT_ATTACH 6 /* Attach Interrupt */
+// OTG Control register
+#define USB0_OTGCTL REG_8(0x4007201C)
+#define OTGCTL_DPHIGH 7 // D+ Data Line pullup resistor enable
+#define OTGCTL_DPLOW 5 // D+ Data Line pull-down resistor enable
+#define OTGCTL_DMLOW 4 // D– Data Line pull-down resistor enable
+#define OTGCTL_OTGEN 2 // On-The-Go pullup/pulldown resistor enable
+
+// Interrupt Status register
+#define USB0_ISTAT REG_8(0x40072080)
+#define ISTAT_STALL 7 // Stall Interrupt
+#define ISTAT_ATTACH 6 // Attach Interrupt
#define ISTAT_RESUME 5
#define ISTAT_SLEEP 4
#define ISTAT_TOKDNE 3
@@ -60,17 +69,19 @@
#define ISTAT_ERROR 1
#define ISTAT_USBRST 0
-#define USB0_INTEN REG_8(0x40072084) /* Interrupt Enable register */
-#define INTEN_STALLEN 7 /* STALL Interrupt Enable */
-#define INTEN_ATTACHEN 6 /* ATTACH Interrupt Enable */
-#define INTEN_RESUMEEN 5 /* RESUME Interrupt Enable */
-#define INTEN_SLEEPEN 4 /* SLEEP Interrupt Enable */
-#define INTEN_TOKDNEEN 3 /* TOKDNE Interrupt Enable */
-#define INTEN_SOFTOKEN 2 /* SOFTOK Interrupt Enable */
-#define INTEN_ERROREN 1 /* ERROR Interrupt Enable */
-#define INTEN_USBRSTEN 0 /* USBRST Interrupt Enable */
-
-#define USB0_ERRSTAT REG_8(0x40072088) /* Error Interrupt Status register */
+// Interrupt Enable register
+#define USB0_INTEN REG_8(0x40072084)
+#define INTEN_STALLEN 7 // STALL Interrupt Enable
+#define INTEN_ATTACHEN 6 // ATTACH Interrupt Enable
+#define INTEN_RESUMEEN 5 // RESUME Interrupt Enable
+#define INTEN_SLEEPEN 4 // SLEEP Interrupt Enable
+#define INTEN_TOKDNEEN 3 // TOKDNE Interrupt Enable
+#define INTEN_SOFTOKEN 2 // SOFTOK Interrupt Enable
+#define INTEN_ERROREN 1 // ERROR Interrupt Enable
+#define INTEN_USBRSTEN 0 // USBRST Interrupt Enable
+
+// Error Interrupt Status register
+#define USB0_ERRSTAT REG_8(0x40072088)
#define ERRSTAT_BTSERR 7
#define ERRSTAT_DMAERR 5
#define ERRSTAT_BTOERR 4
@@ -79,65 +90,79 @@
#define ERRSTAT_CRC5EOF 1
#define ERRSTAT_PIDERR 0
-#define USB0_ERREN REG_8(0x4007208C) /* Error Interrupt Enable register */
-#define ERREN_BTSERREN 7 /* BTSERR Interrupt Enable */
-#define ERREN_DMAERREN 5 /* DMAERR Interrupt Enable */
-#define ERREN_BTOERREN 4 /* BTOERR Interrupt Enable */
-#define ERREN_DFN8EN 3 /* DFN8 Interrupt Enable */
-#define ERREN_CRC16EN 2 /* CRC16 Interrupt Enable */
-#define ERREN_CRC5EOFEN 1 /* CRC5EOF Interrupt Enable */
-#define ERREN_PIDERREN 0 /* PIDERR Interrupt Enable */
-
-#define USB0_STAT REG_8(0x40072090) /* Status register */
+// Error Interrupt Enable register
+#define USB0_ERREN REG_8(0x4007208C)
+#define ERREN_BTSERREN 7 // BTSERR Interrupt Enable
+#define ERREN_DMAERREN 5 // DMAERR Interrupt Enable
+#define ERREN_BTOERREN 4 // BTOERR Interrupt Enable
+#define ERREN_DFN8EN 3 // DFN8 Interrupt Enable
+#define ERREN_CRC16EN 2 // CRC16 Interrupt Enable
+#define ERREN_CRC5EOFEN 1 // CRC5EOF Interrupt Enable
+#define ERREN_PIDERREN 0 // PIDERR Interrupt Enable
+
+// Status register
+#define USB0_STAT REG_8(0x40072090)
#define STAT_ENDP 4
-#define STAT_ENDP_M (uint8_t)(BITS(4) << STAT_ENDP)
-#define STAT_TX 3 /* Transmit Indicator */
+#define STAT_ENDP_M REG_8_M(STAT_ENDP, 4)
+#define STAT_TX 3 // Transmit Indicator
#define STAT_ODD 2
-#define USB0_CTL REG_8(0x40072094) /* Control register */
-#define CTL_JSTATE 7 /* Live USB differential receiver JSTATE signal */
-#define CTL_SE0 6 /* Live USB Single Ended Zero signal */
+// Control register
+#define USB0_CTL REG_8(0x40072094)
+#define CTL_JSTATE 7 // Live USB differential receiver JSTATE signal
+#define CTL_SE0 6 // Live USB Single Ended Zero signal
#define CTL_TXSUSPENDTOKENBUSY 5
#define CTL_RESET 4
#define CTL_HOSTMODEEN 3
#define CTL_RESUME 2
#define CTL_ODDRST 1
-#define CTL_USBENSOFEN 0 /* USB Enable */
+#define CTL_USBENSOFEN 0 // USB Enable
-#define USB0_ADDR REG_8(0x40072098) /* Address register */
+// Address register
+#define USB0_ADDR REG_8(0x40072098)
#define ADDR_LSEN 7
#define ADDR_ADDR 0
-#define ADDR_ADDR_M (uint8_t)(BITS(7))
+#define ADDR_ADDR_M REG_8_M(ADDR_ADDR, 7)
-#define USB0_BDTPAGE1 REG_8(0x4007209C) /* BDT Page Register 1 */
+// BDT Page Register 1
+#define USB0_BDTPAGE1 REG_8(0x4007209C)
+#define BDTPAGE1_BDTBA 1
+#define BDTPAGE1_BDTBA_M REG_8_M(BDTPAGE1_BDTBA, 7)
-#define USB0_FRMNUML REG_8(0x400720A0) /* Frame Number Register Low */
+// Frame Number Register Low
+#define USB0_FRMNUML REG_8(0x400720A0)
#define FRMNUML_FRM 0
-#define FRMNUML_FRM_M (uint8_t)(BITS(8) << FRMNUML_FRM)
+#define FRMNUML_FRM_M REG_8_M(FRMNUML_FRM, 8)
-#define USB0_FRMNUMH REG_8(0x400720A4) /* Frame Number Register High */
+// Frame Number Register High
+#define USB0_FRMNUMH REG_8(0x400720A4)
#define FRMNUMH_FRM 0
-#define FRMNUMH_FRM_M (uint8_t)(BITS(3) << FRMNUMH_FRM_M)
+#define FRMNUMH_FRM_M REG_8_M(FRMNUMH_FRM_M, 3)
-#define USB0_TOKEN REG_8(0x400720A8) /* Token register */
+// Token register
+#define USB0_TOKEN REG_8(0x400720A8)
#define TOKEN_TOKENPID 4
-#define TOKEN_TOKENPID_M (uint8_t)(BITS(4) << TOKEN_TOKENPID)
+#define TOKEN_TOKENPID_M REG_8_M(TOKEN_TOKENPID, 4)
#define TOKEN_TOKENENDPT 0
-#define TOKEN_TOKENENDPT_M (uint8_t)(BITS(4) << TOKEN_TOKENENDPT)
+#define TOKEN_TOKENENDPT_M REG_8_M(TOKEN_TOKENENDPT, 4)
-#define USB0_SOFTHLD REG_8(0x400720AC) /* SOF Threshold Register */
+// SOF Threshold Register
+#define USB0_SOFTHLD REG_8(0x400720AC)
#define SOFTHLD_CNT 0
-#define SOFTHLD_CNT_M (uint8_t)(BITS(8) << SOFTHLD_CNT)
+#define SOFTHLD_CNT_M REG_8_M(SOFTHLD_CNT, 8)
-#define USB0_BDTPAGE2 REG_8(0x400720B0) /* BDT Page Register 2 */
+// BDT Page Register 2
+#define USB0_BDTPAGE2 REG_8(0x400720B0)
#define BDTPAGE2_BDTBA 0
-#define BDTPAGE2_BDTBA_M (uint8_t)(BITS(8) << BDTPAGE2_BDTBA)
+#define BDTPAGE2_BDTBA_M REG_8_M(BDTPAGE2_BDTBA, 8)
-#define USB0_BDTPAGE3 REG_8(0x400720B4) /* BDT Page Register 3 */
+// BDT Page Register 3
+#define USB0_BDTPAGE3 REG_8(0x400720B4)
#define BDTPAGE3_BDTBA 0
-#define BDTPAGE3_BDTBA_M (uint8_t)(BITS(8) << BDTPAGE3_BDTBA)
+#define BDTPAGE3_BDTBA_M REG_8_M(BDTPAGE3_BDTBA, 8)
-#define USB0_ENDPT(n) REG_8(0x400720C0 + 4 * (n)) /* Endpoint Control register */
+// Endpoint Control register
+#define USB0_ENDPT(n) REG_8(0x400720C0 + 4 * (n))
#define ENDPT_HOSTWOHUB 7
#define ENDPT_RETRYDIS 6
#define ENDPT_EPCTLDIS 4
@@ -146,28 +171,34 @@
#define ENDPT_EPSTALL 1
#define ENDPT_EPHSHK 0
-#define USB0_USBCTRL REG_8(0x40072100) /* USB Control register */
-#define USBCTRL_SUSP 7 /* Places the USB transceiver into the suspend state. */
-#define USBCTRL_PDE 6 /* Enables the weak pulldowns on the USB transceiver. */
-
-#define USB0_OBSERVE REG_8(0x40072104) /* USB OTG Observe register */
-#define OBSERVE_DPPU 7 /* Provides observability of the D+ Pullup */
-#define OBSERVE_DPPD 6 /* Provides observability of the D+ Pulldown */
-#define OBSERVE_DMPD 4 /* Provides observability of the D- Pulldown */
-
-#define USB0_CONTROL REG_8(0x40072108) /* USB OTG Control register */
-#define CONTROL_DPPULLUPNONOTG 4 /* DP Pullup in non-OTG device mode state */
-
-#define USB0_USBTRC0 REG_8(0x4007210C) /* USB Transceiver Control Register 0 */
-#define USBTRC0_USBRESET 7 /* USB Reset */
-#define USBTRC0_USBRESMEN 5 /* Asynchronous Resume Interrupt Enable */
-#define USBTRC0_SYNC_DET 1 /* Synchronous USB Interrupt Detect */
-#define USBTRC0_USB_RESUME_INT 0 /* USB Asynchronous Interrupt */
-
-#define USB0_USBFRMADJUST REG_8(0x40072114) /* Frame Adjust Register */
+// USB Control register
+#define USB0_USBCTRL REG_8(0x40072100)
+#define USBCTRL_SUSP 7 // Places the USB transceiver into the suspend state.
+#define USBCTRL_PDE 6 // Enables the weak pulldowns on the USB transceiver.
+
+// USB OTG Observe register
+#define USB0_OBSERVE REG_8(0x40072104)
+#define OBSERVE_DPPU 7 // Provides observability of the D+ Pullup
+#define OBSERVE_DPPD 6 // Provides observability of the D+ Pulldown
+#define OBSERVE_DMPD 4 // Provides observability of the D- Pulldown
+
+// USB OTG Control register
+#define USB0_CONTROL REG_8(0x40072108)
+#define CONTROL_DPPULLUPNONOTG 4 // DP Pullup in non-OTG device mode state
+
+// USB Transceiver Control Register 0
+#define USB0_USBTRC0 REG_8(0x4007210C)
+#define USBTRC0_USBRESET 7 // USB Reset
+#define USBTRC0_USBRESMEN 5 // Asynchronous Resume Interrupt Enable
+#define USBTRC0_SYNC_DET 1 // Synchronous USB Interrupt Detect
+#define USBTRC0_USB_RESUME_INT 0 // USB Asynchronous Interrupt
+
+// Frame Adjust Register
+#define USB0_USBFRMADJUST REG_8(0x40072114)
#define USBFRMADJUST_ADJ 0
-#define USBFRMADJUST_ADJ_M (uint8_t)(BITS(8) << USBFRMADJUST_ADJ)
+#define USBFRMADJUST_ADJ_M REG_8_M(USBFRMADJUST_ADJ, 8)
+// TODO: Move elsewhere
__attribute__ ((packed))
struct usb0_bd {
uint32_t desc;
@@ -176,8 +207,8 @@ struct usb0_bd {
//#define USB0_BD(desc, addr) (struct usb0_bd){(desc), (addr)}
#define USB0_BD_INIT(size, data01) ((size) << BD_BC | BV(BD_OWN) | \
((data01) & 1) << BD_DATA01 | BV(BD_DTS))
-#define BD_BC 16 /* Byte Count */
-#define BD_BC_M (uint32_t)(BITS(10) << BC)
+#define BD_BC 16 // Byte Count
+#define BD_BC_M REG_32_M(BD_BC, 10)
#define BD_OWN 7
#define BD_DATA01 6
#define BD_KEEP 5
@@ -185,7 +216,7 @@ struct usb0_bd {
#define BD_DTS 3
#define BD_BDT_STALL 2
#define BD_TOK_PID 2
-#define BD_TOK_PID_M (uint32_t)(BITS(4) << BD_TOK_PID)
+#define BD_TOK_PID_M REG_32_M(BD_TOK_PID, 4)
#define BD_TOK_PID_OUT 0x1
#define BD_TOK_PID_IN 0x9