freebsd-dev/sys/pci
Bill Paul 23e4757cd7 This commit adds device driver support for the Sundance Technologies ST201
PCI fast ethernet controller. Currently, the only card I know that uses
this chip is the D-Link DFE-550TX. (Don't ask me where to buy these: the
only cards I have are samples sent to me by D-Link.)

This driver is the first to make use of the miibus code once I'm sure
it all works together nicely, I'll start converting the other drivers.

The Sundance chip is a clone of the 3Com 3c90x Etherlink XL design
only with its own register layout. Support is provided for ifmedia,
hardware multicast filtering, bridging and promiscuous mode.
1999-08-21 18:34:58 +00:00
..
adv_pci.c Properly set the alignment argument to bus_dma_tag_create(). If we 1999-08-16 01:52:21 +00:00
adw_pci.c Properly set the alignment argument to bus_dma_tag_create(). If we 1999-08-16 01:52:21 +00:00
ahc_pci.c Differentiate between aic7895C chips and their earlier brethren 1999-08-16 22:50:37 +00:00
alpm.c Alter the behavior of sys/kern/subr_bus.c:device_print_child() 1999-07-29 01:03:04 +00:00
amd.c Properly set the alignment argument to bus_dma_tag_create(). If we 1999-08-16 01:52:21 +00:00
amd.h
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 Alter the behavior of sys/kern/subr_bus.c:device_print_child() 1999-07-29 01:03:04 +00:00
bt848_i2c.h
bt_pci.c Properly set the alignment argument to bus_dma_tag_create(). If we 1999-08-16 01:52:21 +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
dc21040reg.h s/Id/FreeBSD/ 1999-08-09 12:52:49 +00:00
dpt_pci.c Properly set the alignment argument to bus_dma_tag_create(). If we 1999-08-16 01:52:21 +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 Properly set the alignment argument to bus_dma_tag_create(). If we 1999-08-16 01:52:21 +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 Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_alreg.h
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 Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_devar.h A little more tidying up. 1999-08-09 14:43:39 +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 Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_fpa.c Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_fxp.c Rename bpfilter to bpf. 1999-07-06 19:23:32 +00:00
if_fxpreg.h
if_fxpvar.h
if_lnc_p.c Add support for the Am79C978. (AMD PCHome/PCI Ethernet adapter) 1999-08-10 01:03:51 +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 Convert the PNIC driver to newbus. 1999-07-28 02:19:52 +00:00
if_pnreg.h Convert the PNIC driver to newbus. 1999-07-28 02:19:52 +00:00
if_rl.c Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_rlreg.h Fix power management register definitions. 1999-08-21 01:10:45 +00:00
if_sf.c Remember to clear the IFF_RUNNING and IFF_OACTIVE flags in sf_stop() and 1999-07-25 05:16:05 +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 Remember to clear the IFF_RUNNING and IFF_OACTIVE flags in sf_stop() and 1999-07-25 05:16:05 +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_ste.c This commit adds device driver support for the Sundance Technologies ST201 1999-08-21 18:34:58 +00:00
if_stereg.h This commit adds device driver support for the Sundance Technologies ST201 1999-08-21 18:34:58 +00:00
if_ti.c Minor glitch in ti_newbuf_jumbo(): m_adj() was being called on 1999-08-14 15:45:03 +00:00
if_tireg.h On FreeBSD/i386, when you use the SYS_RES_MEMORY resource to allocate 1999-07-27 03:54:48 +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 Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_txvar.h
if_vr.c Small tweak: remember to free the tx ring data (which is malloc()ed) if 1999-08-10 21:12:11 +00:00
if_vrreg.h Convert the VIA Rhine driver to newbus and set it up to be compiled as 1999-08-10 17:15:20 +00:00
if_vx_pci.c Implement a new generic mechanism for attaching handler functions to 1999-08-21 06:24:40 +00:00
if_wb.c Convert the Winbond driver to newbus and have it compiled as a module. 1999-08-10 21:09:12 +00:00
if_wbreg.h Convert the Winbond driver to newbus and have it compiled as a module. 1999-08-10 21:09:12 +00:00
if_xl.c Small tweak: in xl_rxeof(), rxstat should be u_int32_t, not u_int16_t. 1999-08-19 03:47:18 +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 Alter the behavior of sys/kern/subr_bus.c:device_print_child() 1999-07-29 01:03:04 +00:00
intpmreg.h
isp_pci.c Set some correct return values. Prefer I/O map all the time unless configured 1999-08-16 19:52:29 +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
ncrreg.h
ohci_pci.c 1) rename dev->self to be consistent 1999-08-18 10:24:59 +00:00
pci_compat.c Add support for SYS_RES_DENSE and SYS_RES_BWX resource types. These are 1999-07-28 07:57:48 +00:00
pci_if.m
pci_ioctl.h
pci.c Alter the behavior of sys/kern/subr_bus.c:device_print_child() 1999-07-29 01:03:04 +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
pcireg.h
pcisupport.c chip0: <PCI to 0x80 bridge (vendor=10e0 device=8849)> at device 0.0 on pci0 1999-08-09 21:11:44 +00:00
pcivar.h
README.bt848
scsiiom.c
simos.c
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 1) rename dev->self to be consistent 1999-08-18 10:24:59 +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