opnsense-src/sys
Shailend Chand c7aea09126 gve: Add DQO RDA support
DQO is the descriptor format for our next generation virtual NIC.
It is necessary to make full use of the hardware bandwidth on many
newer GCP VM shapes.

One major change with DQO from its predecessor GQI is that it uses
dual descriptor rings for both TX and RX queues.

The TX path uses a descriptor ring to send descriptors to HW, and
receives packet completion events on a TX completion ring.

The RX path posts buffers to HW using an RX descriptor ring and
receives incoming packets on an RX completion ring.

In GQI-QPL, the hardware could not access arbitrary regions of
guest memory, which is why there was a pre-negotitated bounce buffer
(QPL: Queue Page List). DQO-RDA has no such limitation.

"RDA" is in contrast to QPL and stands for "Raw DMA Addressing" which
just means that HW does not need a fixed bounce buffer and can DMA
arbitrary regions of guest memory.

A subsequent patch will introduce the DQO-QPL datapath that uses the
same descriptor format as in this patch, but will have a fixed
bounce buffer.

Signed-off-by: Shailend Chand <shailend@google.com>
Reviewed-by: markj
MFC-after: 2 weeks
Differential Revision: https://reviews.freebsd.org/D46690

(cherry picked from commit d438b4ef0cfc6986b93d0754f49ebf3ead50f269)
2024-11-20 21:41:08 +00:00
..
amd64 vmm: Rename the amdiommu driver to amdviiommu 2024-11-09 21:31:28 +02:00
arm Revert "sound: Make device registration more intuitive" 2024-11-14 17:25:41 +01:00
arm64 iommu: eliminate iommu_free_ctx() 2024-11-09 21:31:28 +02:00
bsm
cam da: Add quirk for ADATA USB Drive 2024-11-12 21:55:04 -07:00
cddl dtrace/amd64: Remove the dtrace_invop_callsite symbol 2024-10-04 15:56:42 +00:00
compat linux sendfile: Fix handling of non-blocking sockets 2024-11-20 21:41:08 +00:00
conf gve: Add DQO RDA support 2024-11-20 21:41:08 +00:00
contrib iwlwifi: script to extract firmware details 2024-11-14 01:53:12 +00:00
crypto openssl: Import OpenSSL 3.0.15. 2024-09-27 20:50:47 -07:00
ddb
dev gve: Add DQO RDA support 2024-11-20 21:41:08 +00:00
dts add allwinner overlays for enabling additional USB ports 2024-02-17 16:15:10 +02:00
fs nfs: Fallback to GID_NOGROUP on no groups 2024-11-15 11:47:43 +01:00
gdb
geom g_eli: update comment for bool return type 2024-11-16 09:59:52 -05:00
gnu
i386 sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
isa
kern busdma_bounce: Replace a SYSINIT with static initializations 2024-11-19 14:15:21 +00:00
kgssapi
libkern arm64: Mark the armv8 crc32c as supporting BTI 2024-02-19 13:17:47 +00:00
modules gve: Add DQO RDA support 2024-11-20 21:41:08 +00:00
net if_tuntap: Enable MEXTPG support 2024-11-11 14:02:30 +00:00
net80211 net80211: scan/internal: change boolean argument from int to bool 2024-09-28 10:35:12 +00:00
netgraph bluetooth(3): Fix two typos in source code comments 2024-09-23 06:50:34 +02:00
netinet sctp: fix debug message 2024-11-06 10:13:14 +01:00
netinet6 netinet: Explicitly disallow connections to the unspecified address 2024-09-20 11:39:16 +00:00
netipsec ipsec esp: avoid dereferencing freed secasindex 2024-03-04 02:27:17 +02:00
netlink netlink: Wrap long lines 2024-07-21 20:55:27 -04:00
netpfil ipfilter: Avoid holding a lock while stopping 2024-11-19 02:32:59 +00:00
netsmb netsmb: Stop checking for failures from malloc(M_WAITOK) 2024-09-30 12:44:16 +08:00
nfs
nfsclient
nfsserver
nlm
ofed ibcore: Mark write-only variables 2024-07-15 12:28:53 +00:00
opencrypto ktls: Remove the socket parameter to ktls_ocf_try() 2024-07-23 09:01:30 -04:00
powerpc ps3: add elfv2 support 2024-10-23 22:08:00 -04:00
riscv sys: add conf/std.debug, generic debugging options 2024-10-09 10:44:35 +02:00
rpc nfs, rpc: Ensure kernel credentials have at least one group 2024-11-15 11:47:43 +01:00
security cred: kern_setgroups(): Internally use int as number of groups' type 2024-11-15 11:47:41 +01:00
sys file: The f_ops table pointer can be a pointer to const 2024-11-19 14:15:07 +00:00
teken
tests tests: Stop checking for failures from malloc(M_WAITOK) 2024-09-30 12:44:18 +08:00
tools amd64: do not pass -z rodynamic to ld.bfd when building vdso 2024-10-24 05:44:40 +03:00
ufs SU+J: all writes to SU journal must be exempt from runningbufspace throttling 2024-11-16 03:07:33 +02:00
vm vm_object: do not assume that un_pager.devp.dev is cdev 2024-11-13 01:19:18 +02:00
x86 amdiommu: short-circuit all amdiommu_find_unit() functions 2024-11-12 02:27:24 +02:00
xdr rpc: Fix the definition of xdr_void() 2024-11-05 01:05:26 +00:00
xen
Makefile
README.md

FreeBSD Kernel Source:

This directory contains the source files and build glue that make up the FreeBSD kernel and its modules, including both original and contributed software.

Kernel configuration files are located in the conf/ subdirectory of each architecture. GENERIC is the configuration used in release builds. NOTES contains documentation of all possible entries. LINT is a compile-only configuration used to maximize build coverage and detect regressions.

Documentation:

Source code documentation is maintained in a set of man pages, under section 9. These pages are located in share/man/man9, from the top-level of the src tree. Consult intro(9) for an overview of existing pages.

Some additional high-level documentation of the kernel is maintained in the Architecture Handbook.

Source Roadmap:

Directory Description
amd64 AMD64 (64-bit x86) architecture support
arm 32-bit ARM architecture support
arm64 64-bit ARM (AArch64) architecture support
cam Common Access Method storage subsystem - cam(4) and ctl(4)
cddl CDDL-licensed optional sources such as DTrace
conf kernel build glue
compat Linux compatibility layer, FreeBSD 32-bit compatibility
contrib 3rd-party imported software such as OpenZFS
crypto crypto drivers
ddb interactive kernel debugger - ddb(4)
fs most filesystems, excluding UFS, NFS, and ZFS
dev device drivers and other arch independent code
gdb kernel remote GDB stub - gdb(4)
geom GEOM framework - geom(4)
i386 i386 (32-bit x86) architecture support
kern main part of the kernel
libkern libc-like and other support functions for kernel use
modules kernel module infrastructure
net core networking code
net80211 wireless networking (IEEE 802.11) - net80211(4)
netgraph graph-based networking subsystem - netgraph(4)
netinet IPv4 protocol implementation - inet(4)
netinet6 IPv6 protocol implementation - inet6(4)
netipsec IPsec protocol implementation - ipsec(4)
netpfil packet filters - ipfw(4), pf(4), and ipfilter(4)
opencrypto OpenCrypto framework - crypto(7)
powerpc PowerPC/POWER (32 and 64-bit) architecture support
riscv 64-bit RISC-V architecture support
security security facilities - audit(4) and mac(4)
sys kernel headers
tests kernel unit tests
ufs Unix File System - ffs(7)
vm virtual memory system
x86 code shared by AMD64 and i386 architectures