FreeBSD Bugzilla – Attachment 186906 Details for
Bug 222634
ffec: Support i.MX7D and performance improvements
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Help
|
New Account
|
Log In
Remember
[x]
|
Forgot Password
Login:
[x]
[patch]
ffec: Use RACC[SHIFT16]
0001-ffec-Use-RACC-SHIFT16.patch (text/plain), 3.71 KB, created by
sebastian.huber
on 2017-10-04 12:46:24 UTC
(
hide
)
Description:
ffec: Use RACC[SHIFT16]
Filename:
MIME Type:
Creator:
sebastian.huber
Created:
2017-10-04 12:46:24 UTC
Size:
3.71 KB
patch
obsolete
>From 6b75e9091153807b8f8dd23d63f75e1a89687d47 Mon Sep 17 00:00:00 2001 >From: Sebastian Huber <sebastian.huber@embedded-brains.de> >Date: Wed, 4 Oct 2017 14:15:59 +0200 >Subject: [PATCH] ffec: Use RACC[SHIFT16] > >This avoids the move of entire receive frames to meet the alignment >requirements of the IP header and so on. > >Add FECFLAG_RACC feature flag for this similar to the Linux driver. >--- > sys/dev/ffec/if_ffec.c | 53 ++++++++++++++++++++++++++++++++++---------------- > 1 file changed, 36 insertions(+), 17 deletions(-) > >diff --git a/sys/dev/ffec/if_ffec.c b/sys/dev/ffec/if_ffec.c >index d38ab76d406..d21a668abd1 100644 >--- a/sys/dev/ffec/if_ffec.c >+++ b/sys/dev/ffec/if_ffec.c >@@ -108,6 +108,7 @@ enum { > #define FECTYPE_MASK 0x0000ffff > #define FECFLAG_GBE (1 << 16) > #define FECFLAG_AVB (1 << 17) >+#define FECFLAG_RACC (1 << 18) > > /* > * Table of supported FDT compat strings and their associated FECTYPE values. >@@ -115,10 +116,11 @@ enum { > static struct ofw_compat_data compat_data[] = { > {"fsl,imx51-fec", FECTYPE_GENERIC}, > {"fsl,imx53-fec", FECTYPE_IMX53}, >- {"fsl,imx6q-fec", FECTYPE_IMX6 | FECFLAG_GBE}, >- {"fsl,imx6ul-fec", FECTYPE_IMX6}, >-+ {"fsl,imx7d-fec", FECTYPE_IMX6 | FECFLAG_GBE | FECFLAG_AVB}, >- {"fsl,mvf600-fec", FECTYPE_MVF}, >+ {"fsl,imx6q-fec", FECTYPE_IMX6 | FECFLAG_GBE | FECFLAG_RACC}, >+ {"fsl,imx6ul-fec", FECTYPE_IMX6 | FECFLAG_RACC}, >+ {"fsl,imx7d-fec", FECTYPE_IMX6 | FECFLAG_GBE | FECFLAG_AVB | >+ FECFLAG_RACC}, >+ {"fsl,mvf600-fec", FECTYPE_MVF | FECFLAG_RACC}, > {"fsl,mvf-fec", FECTYPE_MVF}, > {NULL, FECTYPE_NONE}, > }; >@@ -755,14 +757,17 @@ ffec_setup_rxbuf(struct ffec_softc *sc, int idx, struct mbuf * m) > int error, nsegs; > struct bus_dma_segment seg; > >- /* >- * We need to leave at least ETHER_ALIGN bytes free at the beginning of >- * the buffer to allow the data to be re-aligned after receiving it (by >- * copying it backwards ETHER_ALIGN bytes in the same buffer). We also >- * have to ensure that the beginning of the buffer is aligned to the >- * hardware's requirements. >- */ >- m_adj(m, roundup(ETHER_ALIGN, sc->rxbuf_align)); >+ if ((sc->fectype & FECFLAG_RACC) == 0) { >+ /* >+ * The RACC[SHIFT16] feature is not used. So, we need to leave >+ * at least ETHER_ALIGN bytes free at the beginning of the >+ * buffer to allow the data to be re-aligned after receiving it >+ * (by copying it backwards ETHER_ALIGN bytes in the same >+ * buffer). We also have to ensure that the beginning of the >+ * buffer is aligned to the hardware's requirements. >+ */ >+ m_adj(m, roundup(ETHER_ALIGN, sc->rxbuf_align)); >+ } > > error = bus_dmamap_load_mbuf_sg(sc->rxbuf_tag, sc->rxbuf_map[idx].map, > m, &seg, &nsegs, 0); >@@ -795,7 +800,6 @@ ffec_rxfinish_onebuf(struct ffec_softc *sc, int len) > { > struct mbuf *m, *newmbuf; > struct ffec_bufmap *bmap; >- uint8_t *dst, *src; > int error; > > /* >@@ -839,10 +843,17 @@ ffec_rxfinish_onebuf(struct ffec_softc *sc, int len) > m->m_pkthdr.len = len; > m->m_pkthdr.rcvif = sc->ifp; > >- src = mtod(m, uint8_t*); >- dst = src - ETHER_ALIGN; >- bcopy(src, dst, len); >- m->m_data = dst; >+ if (sc->fectype & FECFLAG_RACC) { >+ /* We use the RACC[SHIFT16] feature */ >+ m->m_data = mtod(m, uint8_t *) + 2; >+ } else { >+ uint8_t *dst, *src; >+ >+ src = mtod(m, uint8_t*); >+ dst = src - ETHER_ALIGN; >+ bcopy(src, dst, len); >+ m->m_data = dst; >+ } > sc->ifp->if_input(sc->ifp, m); > > FFEC_LOCK(sc); >@@ -1216,6 +1227,14 @@ ffec_init_locked(struct ffec_softc *sc) > ffec_clear_stats(sc); > WR4(sc, FEC_MIBC_REG, regval & ~FEC_MIBC_DIS); > >+ if (sc->fectype & FECFLAG_RACC) { >+ /* >+ * RACC - Receive Accelerator Function Configuration. >+ */ >+ regval = RD4(sc, FEC_RACC_REG); >+ WR4(sc, FEC_RACC_REG, regval | FEC_RACC_SHIFT16); >+ } >+ > /* > * ECR - Ethernet control register. > * >-- >2.12.3 >
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 222634
:
186752
|
186753
|
186754
|
186755
|
186905
| 186906