Commit bfcf02ed authored by David Brownell's avatar David Brownell Committed by Tony Lindgren

musb_hdrc cleanup -- cppi and sparse

Cleanup for CPPI DMA (for DaVinci, and someday TUSB6020):

 - Move state ram structs to CPPI header, it's not DaVinci-specific

 - Do some associated CamelCase removal, in conjunction with removing
   inappropriate "volatile" declarations.

This resolves a bunch of "sparse" warnings with this code, most of which
seem to have been caused by bugs in older versions of "sparse".
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
parent 98aaefa1
This diff is collapsed.
...@@ -11,9 +11,39 @@ ...@@ -11,9 +11,39 @@
#include "musb_dma.h" #include "musb_dma.h"
#include "musb_core.h" #include "musb_core.h"
/* FIXME fully isolate CPPI from DaVinci ... the "CPPI generic" registers
* would seem to be shared with the TUSB6020 (over VLYNQ).
*/
#include "davinci.h" #include "davinci.h"
/* CPPI RX/TX state RAM */
struct cppi_tx_stateram {
u32 tx_head; /* "DMA packet" head descriptor */
u32 tx_buf;
u32 tx_current; /* current descriptor */
u32 tx_buf_current;
u32 tx_info; /* flags, remaining buflen */
u32 tx_rem_len;
u32 tx_dummy; /* unused */
u32 tx_complete;
};
struct cppi_rx_stateram {
u32 rx_skipbytes;
u32 rx_head;
u32 rx_sop; /* "DMA packet" head descriptor */
u32 rx_current; /* current descriptor */
u32 rx_buf_current;
u32 rx_len_len;
u32 rx_cnt_cnt;
u32 rx_complete;
};
/* hOptions bit masks for CPPI BDs */ /* hOptions bit masks for CPPI BDs */
#define CPPI_SOP_SET ((u32)(1 << 31)) #define CPPI_SOP_SET ((u32)(1 << 31))
#define CPPI_EOP_SET ((u32)(1 << 30)) #define CPPI_EOP_SET ((u32)(1 << 30))
...@@ -73,7 +103,7 @@ struct cppi_channel { ...@@ -73,7 +103,7 @@ struct cppi_channel {
u32 currOffset; /* requested segments */ u32 currOffset; /* requested segments */
u32 actualLen; /* completed (Channel.actual) */ u32 actualLen; /* completed (Channel.actual) */
void __iomem *stateRam; /* CPPI state */ void __iomem *state_ram; /* CPPI state */
/* BD management fields */ /* BD management fields */
struct cppi_descriptor *bdPoolHead; struct cppi_descriptor *bdPoolHead;
......
...@@ -40,6 +40,8 @@ ...@@ -40,6 +40,8 @@
#define DAVINCI_USB_EOI_REG 0x3c #define DAVINCI_USB_EOI_REG 0x3c
#define DAVINCI_USB_EOI_INTVEC 0x40 #define DAVINCI_USB_EOI_INTVEC 0x40
/* BEGIN CPPI-generic (?) */
/* CPPI related registers */ /* CPPI related registers */
#define DAVINCI_TXCPPI_CTRL_REG 0x80 #define DAVINCI_TXCPPI_CTRL_REG 0x80
#define DAVINCI_TXCPPI_TEAR_REG 0x84 #define DAVINCI_TXCPPI_TEAR_REG 0x84
...@@ -76,30 +78,7 @@ ...@@ -76,30 +78,7 @@
#define DAVINCI_DMA_ALL_CHANNELS_ENABLE 0xF #define DAVINCI_DMA_ALL_CHANNELS_ENABLE 0xF
#define DAVINCI_DMA_ALL_CHANNELS_DISABLE 0xF #define DAVINCI_DMA_ALL_CHANNELS_DISABLE 0xF
/* FIXME relying on "volatile" here is wrong ... */ /* END CPPI-generic (?) */
/* define structures of Rx/Tx stateRam entries */
struct cppi_tx_stateram {
volatile u32 headPtr;
volatile u32 sopDescPtr;
volatile u32 currDescPtr;
volatile u32 currBuffPtr;
volatile u32 flags;
volatile u32 remLength;
volatile u32 dummy;
volatile u32 completionPtr;
};
struct cppi_rx_stateram {
volatile u32 buffOffset;
volatile u32 headPtr;
volatile u32 sopDescPtr;
volatile u32 currDescPtr;
volatile u32 currBuffPtr;
volatile u32 pktLength;
volatile u32 byteCount;
volatile u32 completionPtr;
};
#define DAVINCI_USB_TX_ENDPTS_MASK 0x1f /* ep0 + 4 tx */ #define DAVINCI_USB_TX_ENDPTS_MASK 0x1f /* ep0 + 4 tx */
#define DAVINCI_USB_RX_ENDPTS_MASK 0x1e /* 4 rx */ #define DAVINCI_USB_RX_ENDPTS_MASK 0x1e /* 4 rx */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment