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:
parent
c13fd8d42b
commit
f1eac1007e
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=199676
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user