1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-24 16:10:11 +00:00

Correct register access for USB device side operation on the musb controller.

Submitted by:	Hans Petter Selasky
This commit is contained in:
Andrew Thompson 2009-11-22 21:24:38 +00:00
parent c13fd8d42b
commit f1eac1007e
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=199676

View File

@ -1539,18 +1539,18 @@ musbotg_clear_stall_sub(struct musbotg_softc *sc, uint16_t wMaxPacket,
/* Configure endpoint */ /* Configure endpoint */
switch (ep_type) { switch (ep_type) {
case UE_INTERRUPT: case UE_INTERRUPT:
MUSB2_WRITE_1(sc, MUSB2_REG_TXMAXP, wMaxPacket); MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, wMaxPacket);
MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH,
MUSB2_MASK_CSRH_TXMODE | temp); MUSB2_MASK_CSRH_TXMODE | temp);
break; break;
case UE_ISOCHRONOUS: case UE_ISOCHRONOUS:
MUSB2_WRITE_1(sc, MUSB2_REG_TXMAXP, wMaxPacket); MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, wMaxPacket);
MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH,
MUSB2_MASK_CSRH_TXMODE | MUSB2_MASK_CSRH_TXMODE |
MUSB2_MASK_CSRH_TXISO | temp); MUSB2_MASK_CSRH_TXISO | temp);
break; break;
case UE_BULK: case UE_BULK:
MUSB2_WRITE_1(sc, MUSB2_REG_TXMAXP, wMaxPacket); MUSB2_WRITE_2(sc, MUSB2_REG_TXMAXP, wMaxPacket);
MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH, MUSB2_WRITE_1(sc, MUSB2_REG_TXCSRH,
MUSB2_MASK_CSRH_TXMODE | temp); MUSB2_MASK_CSRH_TXMODE | temp);
break; break;
@ -1600,18 +1600,18 @@ musbotg_clear_stall_sub(struct musbotg_softc *sc, uint16_t wMaxPacket,
/* Configure endpoint */ /* Configure endpoint */
switch (ep_type) { switch (ep_type) {
case UE_INTERRUPT: case UE_INTERRUPT:
MUSB2_WRITE_1(sc, MUSB2_REG_RXMAXP, wMaxPacket); MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, wMaxPacket);
MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH,
MUSB2_MASK_CSRH_RXNYET | temp); MUSB2_MASK_CSRH_RXNYET | temp);
break; break;
case UE_ISOCHRONOUS: case UE_ISOCHRONOUS:
MUSB2_WRITE_1(sc, MUSB2_REG_RXMAXP, wMaxPacket); MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, wMaxPacket);
MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH,
MUSB2_MASK_CSRH_RXNYET | MUSB2_MASK_CSRH_RXNYET |
MUSB2_MASK_CSRH_RXISO | temp); MUSB2_MASK_CSRH_RXISO | temp);
break; break;
case UE_BULK: case UE_BULK:
MUSB2_WRITE_1(sc, MUSB2_REG_RXMAXP, wMaxPacket); MUSB2_WRITE_2(sc, MUSB2_REG_RXMAXP, wMaxPacket);
MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, temp); MUSB2_WRITE_1(sc, MUSB2_REG_RXCSRH, temp);
break; break;
default: default:
@ -1688,12 +1688,14 @@ usb_error_t
musbotg_init(struct musbotg_softc *sc) musbotg_init(struct musbotg_softc *sc)
{ {
struct usb_hw_ep_profile *pf; struct usb_hw_ep_profile *pf;
uint16_t offset;
uint8_t nrx; uint8_t nrx;
uint8_t ntx; uint8_t ntx;
uint8_t temp; uint8_t temp;
uint8_t fsize; uint8_t fsize;
uint8_t frx; uint8_t frx;
uint8_t ftx; uint8_t ftx;
uint8_t dynfifo;
DPRINTFN(1, "start\n"); DPRINTFN(1, "start\n");
@ -1776,11 +1778,20 @@ musbotg_init(struct musbotg_softc *sc)
DPRINTFN(2, "Config Data: 0x%02x\n", DPRINTFN(2, "Config Data: 0x%02x\n",
sc->sc_conf_data); sc->sc_conf_data);
dynfifo = (sc->sc_conf_data & MUSB2_MASK_CD_DYNFIFOSZ) ? 1 : 0;
if (dynfifo) {
DPRINTFN(0, "Dynamic FIFO sizing detected! "
"Assuming 16Kbytes of FIFO RAM\n");
}
DPRINTFN(2, "HW version: 0x%04x\n", DPRINTFN(2, "HW version: 0x%04x\n",
MUSB2_READ_1(sc, MUSB2_REG_HWVERS)); MUSB2_READ_1(sc, MUSB2_REG_HWVERS));
/* initialise endpoint profiles */ /* initialise endpoint profiles */
offset = 0;
for (temp = 1; temp <= sc->sc_ep_max; temp++) { for (temp = 1; temp <= sc->sc_ep_max; temp++) {
pf = sc->sc_hw_ep_profile + temp; pf = sc->sc_hw_ep_profile + temp;
@ -1791,9 +1802,45 @@ musbotg_init(struct musbotg_softc *sc)
frx = (fsize & MUSB2_MASK_RX_FSIZE) / 16;; frx = (fsize & MUSB2_MASK_RX_FSIZE) / 16;;
ftx = (fsize & MUSB2_MASK_TX_FSIZE); ftx = (fsize & MUSB2_MASK_TX_FSIZE);
DPRINTF("Endpoint %u FIFO size: IN=%u, OUT=%u\n", DPRINTF("Endpoint %u FIFO size: IN=%u, OUT=%u, DYN=%d\n",
temp, pf->max_in_frame_size, temp, ftx, frx, dynfifo);
pf->max_out_frame_size);
if (dynfifo) {
if (frx && (temp <= nrx)) {
if (temp < 8) {
frx = 10; /* 1K */
MUSB2_WRITE_1(sc, MUSB2_REG_RXFIFOSZ,
MUSB2_VAL_FIFOSZ_512 |
MUSB2_MASK_FIFODB);
} else {
frx = 7; /* 128 bytes */
MUSB2_WRITE_1(sc, MUSB2_REG_RXFIFOSZ,
MUSB2_VAL_FIFOSZ_128);
}
MUSB2_WRITE_2(sc, MUSB2_REG_RXFIFOADD,
offset >> 3);
offset += (1 << frx);
}
if (ftx && (temp <= ntx)) {
if (temp < 8) {
ftx = 10; /* 1K */
MUSB2_WRITE_1(sc, MUSB2_REG_TXFIFOSZ,
MUSB2_VAL_FIFOSZ_512 |
MUSB2_MASK_FIFODB);
} else {
ftx = 7; /* 128 bytes */
MUSB2_WRITE_1(sc, MUSB2_REG_TXFIFOSZ,
MUSB2_VAL_FIFOSZ_128);
}
MUSB2_WRITE_2(sc, MUSB2_REG_TXFIFOADD,
offset >> 3);
offset += (1 << ftx);
}
}
if (frx && ftx && (temp <= nrx) && (temp <= ntx)) { if (frx && ftx && (temp <= nrx) && (temp <= ntx)) {
pf->max_in_frame_size = 1 << ftx; pf->max_in_frame_size = 1 << ftx;
@ -1824,6 +1871,8 @@ musbotg_init(struct musbotg_softc *sc)
} }
} }
DPRINTFN(2, "Dynamic FIFO size = %d bytes\n", offset);
/* turn on default interrupts */ /* turn on default interrupts */
MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE, MUSB2_WRITE_1(sc, MUSB2_REG_INTUSBE,