- Implement the RX EARLYOFF and RXDV GATED bits as done by RealTek's Linux
driver as version 8.037.00 for RTL8168{E-VL,EP,F,G,GU} and RTL8111B. This makes reception of packets work with the RTL8168G (HW rev. 0x4c000000) in my Shuttle DS47. - Consistently use RL_MSI_MESSAGES. In joint forces with: yongari MFC after: 5 days
This commit is contained in:
parent
06622912a6
commit
d04984a2d2
@ -656,6 +656,10 @@ re_set_rxmode(struct rl_softc *sc)
|
|||||||
ifp = sc->rl_ifp;
|
ifp = sc->rl_ifp;
|
||||||
|
|
||||||
rxfilt = RL_RXCFG_CONFIG | RL_RXCFG_RX_INDIV | RL_RXCFG_RX_BROAD;
|
rxfilt = RL_RXCFG_CONFIG | RL_RXCFG_RX_INDIV | RL_RXCFG_RX_BROAD;
|
||||||
|
if ((sc->rl_flags & RL_FLAG_EARLYOFF) != 0)
|
||||||
|
rxfilt |= RL_RXCFG_EARLYOFF;
|
||||||
|
else if ((sc->rl_flags & RL_FLAG_EARLYOFFV2) != 0)
|
||||||
|
rxfilt |= RL_RXCFG_EARLYOFFV2;
|
||||||
|
|
||||||
if (ifp->if_flags & (IFF_ALLMULTI | IFF_PROMISC)) {
|
if (ifp->if_flags & (IFF_ALLMULTI | IFF_PROMISC)) {
|
||||||
if (ifp->if_flags & IFF_PROMISC)
|
if (ifp->if_flags & IFF_PROMISC)
|
||||||
@ -1265,7 +1269,7 @@ re_attach(device_t dev)
|
|||||||
msic = 0;
|
msic = 0;
|
||||||
/* Prefer MSI-X to MSI. */
|
/* Prefer MSI-X to MSI. */
|
||||||
if (msixc > 0) {
|
if (msixc > 0) {
|
||||||
msixc = 1;
|
msixc = RL_MSI_MESSAGES;
|
||||||
rid = PCIR_BAR(4);
|
rid = PCIR_BAR(4);
|
||||||
sc->rl_res_pba = bus_alloc_resource_any(dev, SYS_RES_MEMORY,
|
sc->rl_res_pba = bus_alloc_resource_any(dev, SYS_RES_MEMORY,
|
||||||
&rid, RF_ACTIVE);
|
&rid, RF_ACTIVE);
|
||||||
@ -1275,7 +1279,7 @@ re_attach(device_t dev)
|
|||||||
}
|
}
|
||||||
if (sc->rl_res_pba != NULL &&
|
if (sc->rl_res_pba != NULL &&
|
||||||
pci_alloc_msix(dev, &msixc) == 0) {
|
pci_alloc_msix(dev, &msixc) == 0) {
|
||||||
if (msixc == 1) {
|
if (msixc == RL_MSI_MESSAGES) {
|
||||||
device_printf(dev, "Using %d MSI-X message\n",
|
device_printf(dev, "Using %d MSI-X message\n",
|
||||||
msixc);
|
msixc);
|
||||||
sc->rl_flags |= RL_FLAG_MSIX;
|
sc->rl_flags |= RL_FLAG_MSIX;
|
||||||
@ -1292,7 +1296,7 @@ re_attach(device_t dev)
|
|||||||
}
|
}
|
||||||
/* Prefer MSI to INTx. */
|
/* Prefer MSI to INTx. */
|
||||||
if (msixc == 0 && msic > 0) {
|
if (msixc == 0 && msic > 0) {
|
||||||
msic = 1;
|
msic = RL_MSI_MESSAGES;
|
||||||
if (pci_alloc_msi(dev, &msic) == 0) {
|
if (pci_alloc_msi(dev, &msic) == 0) {
|
||||||
if (msic == RL_MSI_MESSAGES) {
|
if (msic == RL_MSI_MESSAGES) {
|
||||||
device_printf(dev, "Using %d MSI message\n",
|
device_printf(dev, "Using %d MSI message\n",
|
||||||
@ -1463,16 +1467,24 @@ re_attach(device_t dev)
|
|||||||
RL_FLAG_WOL_MANLINK;
|
RL_FLAG_WOL_MANLINK;
|
||||||
break;
|
break;
|
||||||
case RL_HWREV_8168E_VL:
|
case RL_HWREV_8168E_VL:
|
||||||
case RL_HWREV_8168EP:
|
|
||||||
case RL_HWREV_8168F:
|
case RL_HWREV_8168F:
|
||||||
case RL_HWREV_8168G:
|
sc->rl_flags |= RL_FLAG_EARLYOFF;
|
||||||
|
/* FALLTHROUGH */
|
||||||
case RL_HWREV_8411:
|
case RL_HWREV_8411:
|
||||||
case RL_HWREV_8411B:
|
|
||||||
sc->rl_flags |= RL_FLAG_PHYWAKE | RL_FLAG_PAR |
|
sc->rl_flags |= RL_FLAG_PHYWAKE | RL_FLAG_PAR |
|
||||||
RL_FLAG_DESCV2 | RL_FLAG_MACSTAT | RL_FLAG_CMDSTOP |
|
RL_FLAG_DESCV2 | RL_FLAG_MACSTAT | RL_FLAG_CMDSTOP |
|
||||||
RL_FLAG_AUTOPAD | RL_FLAG_JUMBOV2 |
|
RL_FLAG_AUTOPAD | RL_FLAG_JUMBOV2 |
|
||||||
RL_FLAG_CMDSTOP_WAIT_TXQ | RL_FLAG_WOL_MANLINK;
|
RL_FLAG_CMDSTOP_WAIT_TXQ | RL_FLAG_WOL_MANLINK;
|
||||||
break;
|
break;
|
||||||
|
case RL_HWREV_8168EP:
|
||||||
|
case RL_HWREV_8168G:
|
||||||
|
case RL_HWREV_8411B:
|
||||||
|
sc->rl_flags |= RL_FLAG_PHYWAKE | RL_FLAG_PAR |
|
||||||
|
RL_FLAG_DESCV2 | RL_FLAG_MACSTAT | RL_FLAG_CMDSTOP |
|
||||||
|
RL_FLAG_AUTOPAD | RL_FLAG_JUMBOV2 |
|
||||||
|
RL_FLAG_CMDSTOP_WAIT_TXQ | RL_FLAG_WOL_MANLINK |
|
||||||
|
RL_FLAG_EARLYOFFV2 | RL_FLAG_RXDV_GATED;
|
||||||
|
break;
|
||||||
case RL_HWREV_8168GU:
|
case RL_HWREV_8168GU:
|
||||||
if (pci_get_device(dev) == RT_DEVICEID_8101E) {
|
if (pci_get_device(dev) == RT_DEVICEID_8101E) {
|
||||||
/* RTL8106EUS */
|
/* RTL8106EUS */
|
||||||
@ -1482,7 +1494,8 @@ re_attach(device_t dev)
|
|||||||
|
|
||||||
sc->rl_flags |= RL_FLAG_PHYWAKE | RL_FLAG_PAR |
|
sc->rl_flags |= RL_FLAG_PHYWAKE | RL_FLAG_PAR |
|
||||||
RL_FLAG_DESCV2 | RL_FLAG_MACSTAT | RL_FLAG_CMDSTOP |
|
RL_FLAG_DESCV2 | RL_FLAG_MACSTAT | RL_FLAG_CMDSTOP |
|
||||||
RL_FLAG_AUTOPAD | RL_FLAG_CMDSTOP_WAIT_TXQ;
|
RL_FLAG_AUTOPAD | RL_FLAG_CMDSTOP_WAIT_TXQ |
|
||||||
|
RL_FLAG_EARLYOFFV2 | RL_FLAG_RXDV_GATED;
|
||||||
break;
|
break;
|
||||||
case RL_HWREV_8169_8110SB:
|
case RL_HWREV_8169_8110SB:
|
||||||
case RL_HWREV_8169_8110SBL:
|
case RL_HWREV_8169_8110SBL:
|
||||||
@ -3170,6 +3183,10 @@ re_init_locked(struct rl_softc *sc)
|
|||||||
CSR_WRITE_4(sc, RL_TXLIST_ADDR_LO,
|
CSR_WRITE_4(sc, RL_TXLIST_ADDR_LO,
|
||||||
RL_ADDR_LO(sc->rl_ldata.rl_tx_list_addr));
|
RL_ADDR_LO(sc->rl_ldata.rl_tx_list_addr));
|
||||||
|
|
||||||
|
if ((sc->rl_flags & RL_FLAG_RXDV_GATED) != 0)
|
||||||
|
CSR_WRITE_4(sc, RL_MISC, CSR_READ_4(sc, RL_MISC) &
|
||||||
|
~0x00080000);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable transmit and receive.
|
* Enable transmit and receive.
|
||||||
*/
|
*/
|
||||||
|
@ -145,6 +145,7 @@
|
|||||||
#define RL_PMCH 0x006F /* 8 bits */
|
#define RL_PMCH 0x006F /* 8 bits */
|
||||||
#define RL_MAXRXPKTLEN 0x00DA /* 16 bits, chip multiplies by 8 */
|
#define RL_MAXRXPKTLEN 0x00DA /* 16 bits, chip multiplies by 8 */
|
||||||
#define RL_INTRMOD 0x00E2 /* 16 bits */
|
#define RL_INTRMOD 0x00E2 /* 16 bits */
|
||||||
|
#define RL_MISC 0x00F0
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* TX config register bits
|
* TX config register bits
|
||||||
@ -286,8 +287,10 @@
|
|||||||
#define RL_RXCFG_RX_RUNT 0x00000010
|
#define RL_RXCFG_RX_RUNT 0x00000010
|
||||||
#define RL_RXCFG_RX_ERRPKT 0x00000020
|
#define RL_RXCFG_RX_ERRPKT 0x00000020
|
||||||
#define RL_RXCFG_WRAP 0x00000080
|
#define RL_RXCFG_WRAP 0x00000080
|
||||||
|
#define RL_RXCFG_EARLYOFFV2 0x00000800
|
||||||
#define RL_RXCFG_MAXDMA 0x00000700
|
#define RL_RXCFG_MAXDMA 0x00000700
|
||||||
#define RL_RXCFG_BUFSZ 0x00001800
|
#define RL_RXCFG_BUFSZ 0x00001800
|
||||||
|
#define RL_RXCFG_EARLYOFF 0x00003800
|
||||||
#define RL_RXCFG_FIFOTHRESH 0x0000E000
|
#define RL_RXCFG_FIFOTHRESH 0x0000E000
|
||||||
#define RL_RXCFG_EARLYTHRESH 0x07000000
|
#define RL_RXCFG_EARLYTHRESH 0x07000000
|
||||||
|
|
||||||
@ -926,6 +929,9 @@ struct rl_softc {
|
|||||||
#define RL_FLAG_WAIT_TXPOLL 0x00004000
|
#define RL_FLAG_WAIT_TXPOLL 0x00004000
|
||||||
#define RL_FLAG_CMDSTOP_WAIT_TXQ 0x00008000
|
#define RL_FLAG_CMDSTOP_WAIT_TXQ 0x00008000
|
||||||
#define RL_FLAG_WOL_MANLINK 0x00010000
|
#define RL_FLAG_WOL_MANLINK 0x00010000
|
||||||
|
#define RL_FLAG_EARLYOFF 0x00020000
|
||||||
|
#define RL_FLAG_EARLYOFFV2 0x00040000
|
||||||
|
#define RL_FLAG_RXDV_GATED 0x00080000
|
||||||
#define RL_FLAG_PCIE 0x40000000
|
#define RL_FLAG_PCIE 0x40000000
|
||||||
#define RL_FLAG_LINK 0x80000000
|
#define RL_FLAG_LINK 0x80000000
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user