1
0
mirror of https://git.FreeBSD.org/src.git synced 2024-12-14 10:09:48 +00:00
freebsd/sys/pci
Bill Paul 691c152864 This commit adds device driver support for Adaptec Duralink PCI fast
ethernet controllers based on the AIC-6915 "Starfire" controller chip.
There are single port, dual port and quad port cards, plus one 100baseFX
card. All are 64-bit PCI devices, except one single port model.

The Starfire would be a very nice chip were it not for the fact that
receive buffers have to be longword aligned. This requires buffer
copying in order to achieve proper payload alignment on the alpha.
Payload alignment is enforced on both the alpha and x86 platforms.
The Starfire has several different DMA descriptor formats and transfer
mechanisms. This driver uses frame descriptors for transmission which
can address up to 14 packet fragments, and a single fragment descriptor
for receive. It also uses the producer/consumer model and completion
queues for both transmit and receive. The transmit ring has 128
descriptors and the receive ring has 256.

This driver supports both FreeBSD/i386 and FreeBSD/alpha, and uses newbus
so that it can be compiled as a loadable kernel module. Support for BPF
and hardware multicast filtering is included.
1999-07-25 04:32:50 +00:00
..
adv_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
adw_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
ahc_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
alpm.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
amd.c First cut at a driver for the amd53c974 PCI SCSI host adapter. This 1999-05-22 21:50:40 +00:00
amd.h First cut at a driver for the amd53c974 PCI SCSI host adapter. This 1999-05-22 21:50:40 +00:00
brktree_reg.h Bug fixes 1999-07-12 15:51:50 +00:00
brooktree848.c Bug fixes 1999-07-12 15:51:50 +00:00
bt848_i2c.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
bt848_i2c.h
bt_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
cy_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
cy_pcireg.h Detect PCI device IDs for latest boards. Simplified the ID comparisons. 1999-05-10 10:23:40 +00:00
dc21040reg.h
dpt_pci.c Simplify the COMPAT_PCI_DRIVER/DATA_SET hack. We can add: 1999-05-09 17:07:30 +00:00
dpt_pci.h
es1370_reg.h
es1370.c Only have the pci component compiled if pci is specified at config. 1999-07-03 18:34:04 +00:00
ida_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
ide_pci.c Revert out part of the last patch that can be done better elsewhere. 1999-07-22 21:08:02 +00:00
ide_pcireg.h
if_al.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_alreg.h Allow chipset drivers to specify the direct-mapped DMA window's mask in 1999-05-26 23:01:57 +00:00
if_ax.c Convert the ASIX and Macronix drivers to newbus. 1999-07-24 20:52:57 +00:00
if_axreg.h Convert the ASIX and Macronix drivers to newbus. 1999-07-24 20:52:57 +00:00
if_de.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_devar.h Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_ed_p.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
if_en_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
if_fpa.c Simplify the COMPAT_PCI_DRIVER/DATA_SET hack. We can add: 1999-05-09 17:07:30 +00:00
if_fxp.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_fxpreg.h Define more registers and fix incorrect (but unused) register bit definitions. 1999-02-11 23:41:21 +00:00
if_fxpvar.h Bring the 'new-bus' to the i386. This extensively changes the way the 1999-04-16 21:22:55 +00:00
if_lnc_p.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
if_mx.c Convert the ASIX and Macronix drivers to newbus. 1999-07-24 20:52:57 +00:00
if_mxreg.h Convert the ASIX and Macronix drivers to newbus. 1999-07-24 20:52:57 +00:00
if_pn.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_pnreg.h Minor nit - pn_cachesize is not a PN_RX_BUG_WAR varible. 1999-07-04 04:21:29 +00:00
if_rl.c Remove the definitions for the SiS 900 chip. This is not a RealTek 1999-07-22 20:56:49 +00:00
if_rlreg.h Remove the definitions for the SiS 900 chip. This is not a RealTek 1999-07-22 20:56:49 +00:00
if_sf.c This commit adds device driver support for Adaptec Duralink PCI fast 1999-07-25 04:32:50 +00:00
if_sfreg.h This commit adds device driver support for Adaptec Duralink PCI fast 1999-07-25 04:32:50 +00:00
if_sk.c One last tweak before I turn in for the evening: the driver name in 1999-07-23 05:50:35 +00:00
if_skreg.h Dangit. Somehow the pmap_kextract hack for alpha snuck back into these 1999-07-23 02:18:01 +00:00
if_sr_p.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
if_ti.c Clean up the buffer allocation code a bit. Make sure to initialize certain 1999-07-23 18:46:24 +00:00
if_tireg.h Clean up the buffer allocation code a bit. Make sure to initialize certain 1999-07-23 18:46:24 +00:00
if_tl.c Some more small newbus cleanups. Remember to free all resources in case 1999-07-23 02:06:57 +00:00
if_tlreg.h Dangit. Somehow the pmap_kextract hack for alpha snuck back into these 1999-07-23 02:18:01 +00:00
if_tx.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_txvar.h Move arpcom structure be the first in softc structure. Needed 1999-05-22 06:10:14 +00:00
if_vr.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_vrreg.h Tweak the Macronix driver to hopefully make it more reliable: 1999-05-06 15:32:52 +00:00
if_vx_pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
if_wb.c Make the Winbond ethernet driver work on FreeBSD/alpha. Also added 1999-07-11 00:56:07 +00:00
if_wbreg.h Make the Winbond ethernet driver work on FreeBSD/alpha. Also added 1999-07-11 00:56:07 +00:00
if_xl.c Some more small newbus cleanups. Remember to free all resources in case 1999-07-23 02:06:57 +00:00
if_xlreg.h Convert the xl driver to newbus. It is now possible to make this driver 1999-07-20 21:23:17 +00:00
intpm.c Update intpm driver. 1999-07-24 19:13:54 +00:00
intpmreg.h SMBus support for the Intel PIIX4 power management unit. See smbus(4), 1999-01-24 18:13:31 +00:00
isp_pci.c add in a boot environment isp_disable flag 1999-07-06 01:24:20 +00:00
locate.pl
meteor_reg.h
meteor.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
ncr.c #include <machine/md_var.h> to get prototype for alpha_register_pci_scsi(). 1999-07-01 22:00:12 +00:00
ncrreg.h
ohci_pci.c Shorten the strings a bit (remove 'Host') 1999-06-13 20:46:10 +00:00
pci_compat.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
pci_if.m Bring the 'new-bus' to the i386. This extensively changes the way the 1999-04-16 21:22:55 +00:00
pci_ioctl.h
pci.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
pcic_p.c Eliminate a bunch of #include "pci.h" and #if NPCI > 0 around entire 1999-07-03 20:17:08 +00:00
pcic_p.h - Added PCI identification support for the TI1251 PCI/CardBus bridge. 1999-05-02 05:53:50 +00:00
pcireg.h Bring the 'new-bus' to the i386. This extensively changes the way the 1999-04-16 21:22:55 +00:00
pcisupport.c Add support for multiple PCI busses directly connected to the nexus. 1999-07-16 01:00:30 +00:00
pcivar.h On the new Meteor cards, the Philips SAA 7116 is connected to the PCI bus 1999-05-31 22:13:37 +00:00
README.bt848
scsiiom.c
simos.c Simplify the COMPAT_PCI_DRIVER/DATA_SET hack. We can add: 1999-05-09 17:07:30 +00:00
simos.h
ti_fw2.h Convert the Alteon Tigon gigabit ethernet driver to newbus. Also upgrade 1999-07-23 02:10:11 +00:00
ti_fw.h Convert the Alteon Tigon gigabit ethernet driver to newbus. Also upgrade 1999-07-23 02:10:11 +00:00
uhci_pci.c Remove option USBVERBOSE 1999-06-16 17:34:36 +00:00
xmaciireg.h This commit adds driver support for the SysKonnect SK-984x series 1999-07-09 04:30:09 +00:00
xrpu.c dont allow open if no device was found. 1999-07-13 08:15:22 +00:00

-------------------------------------------------------------------------------
Recent versions of 3.0-current have the bktr driver built in.  Older versions
of 3.0 and all versions of 2.2 need to have the driver files installed by hand:

cp ioctl_bt848.h /sys/i386/include/
cp brktree_reg.h brooktree848.c /sys/pci/

In /sys/conf/files add:
pci/brooktree848.c        optional bktr device-driver

-------------------------------------------------------------------------------
In all cases you will need to add the driver to your kernel:

In your kernel configuration file:
controller      pci0     #if you already have this line don't add it.
device          bktr0    

There is no need to specify DMA channels nor interrupts for this
driver.

-------------------------------------------------------------------------------
Finally you need to create nodes for the driver:

Create a video device:
mknod /dev/bktr0 c 92 0

Create a tuner device:
mknod /dev/tuner0 c 92 16

-------------------------------------------------------------------------------
The code attempts to auto-probe code to detect card/tuner types.
The detected card is printed in the dmesg as the driver is loaded.  If
this fails to detect the proper card you can override it in brooktree848.c:

#define OVERRIDE_CARD	<card type>

where <card type> is one of:
	CARD_UNKNOWN
	CARD_MIRO
	CARD_HAUPPAUGE
	CARD_STB
	CARD_INTEL

-------------------------------------------------------------------------------
This model now separates the "tuner control" items into a minor device:

minor device layout:  xxxxxxxx xxxT UUUU

 UUUU:   the card (ie UNIT) identifier, 0 thru 15
 T == 0: video device
 T == 1: tuner device

Access your tuner ioctl thru your tuner device handle and anything
which controls the video capture process thru the video device handle.

Certain ioctl()s such as video source are available thru both devices.

-------------------------------------------------------------------------------
If your tuner does not work properly or is not recognized properly
try setting the tuner type via or card type:
sysctl -w hw.bt848.card=<integer> current valid values are 0 to 5 inclusive
sysctl -w hw.bt848.tuner=<integer> where integer is a value from 1 to 10
systcl -w hw.bt848.reverse_mute=<1 | 0> to reverse the mute function in the
                                driver set variable to 1.
The exact format of the sysctl bt848 variable is:
unit << 8 | value

unit identifies the pci bt848 board to be affected 0 is the first bt848 
board, 1 is the second bt848 board.
value denotes the integer value for tuners is a value from 0 to 10 for
reversing the mute function of the tuner the value is 1 or 0.

to find out all the bt848 variables:
sysctl hw.bt848



-------------------------------------------------------------------------------
The bt848 driver consists of:

src/sys/i386/include/ioctl_bt848.h
src/sys/pci/brktree_reg.h
src/sys/pci/brooktree848.c