freebsd-skq/sys/pci
wpaul fa6cd402be Convert the ThunderLAN driver to miibus. This took me a while because I
had to get the ML 6692 PHY driver working correctly, which is harder than
it sounds. "Bitrate" ThunderLAN devices should still be supported (i.e
the older 10Mbps Netflex 3/P, which use the TNETE110 chip that has no
MII support). The ThunderLAN has an internal PHY which makes things a
little complicated, but these are the basic rules:

- For devices with just the ThunderLAN, the internal PHY is used to
  provide 10baseT, and 10base5/10baseT support. Autonegotiation will
  work, but only with 10baseT links. The only thing that really gets
  negotiated is whether the link is full or half duplex.

- For devices with the ThunderLAN and an external 10/100 PHY (like the
  Compaq Netelligent 100Mbps cards, or the internal Netflex 3/P with
  100Mbps upgrade daughter card), the external PHY is used for 10baseT
  and 100baseTX modes. The internal PHY is still used to support
  10base5/10base2, though you have to select them manual with ifconfig.

- For devices with the ThunderLAN and the ML6692 PHY, both the internal
  and external PHYs are used, though it will appear as though the 6692
  PHY will be used to support 10baseT and 100baseTX modes. In reality,
  the internal PHY will be used for 10baseT, but this fact will be hidden
  from the user. The 10base5/10base2 modes can also be selected manually
  as with above.
1999-08-27 18:58:27 +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 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 Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +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 Detect PCI device IDs for latest boards. Simplified the ID comparisons. 1999-05-10 10:23:40 +00:00
dc21040reg.h s/Id/FreeBSD/ 1999-08-09 12:52:49 +00:00
dpt_pci.c Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +00:00
dpt_pci.h
es1370_reg.h Add Joachim Kuebart's ES1370 driver. With my Shuttle HOT-255 card, 1998-12-31 08:14:27 +00:00
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 Cast pointers to uintptr_t instead of casting them to u_long, and/or vice 1999-08-24 00:56:50 +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 Add missing include. 1999-08-21 21:35:59 +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 Clean up after removing sys/eventhandler.h from sys/systm.h at the last 1999-08-21 22:10:49 +00:00
if_fpa.c Clean up after removing sys/eventhandler.h from sys/systm.h at the last 1999-08-21 22:10:49 +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 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 Change PN_RXLEN from 1518 bytes to 1536 bytes. The chip always DMAs data 1999-08-24 03:19:45 +00:00
if_pnreg.h Change PN_RXLEN from 1518 bytes to 1536 bytes. The chip always DMAs data 1999-08-24 03:19:45 +00:00
if_rl.c Clean up after removing sys/eventhandler.h from sys/systm.h at the last 1999-08-21 22:10:49 +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 Properly re-enable the transmitter in the TX error handler. 1999-08-26 05:31:53 +00:00
if_stereg.h Remove MII/PHY related junk from here. It's not needed anymore. 1999-08-21 19:03:37 +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 Convert the ThunderLAN driver to miibus. This took me a while because I 1999-08-27 18:58:27 +00:00
if_tlreg.h Convert the ThunderLAN driver to miibus. This took me a while because I 1999-08-27 18:58:27 +00:00
if_tx.c Clean up after removing sys/eventhandler.h from sys/systm.h at the last 1999-08-21 22:10:49 +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 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 Clean up after removing sys/eventhandler.h from sys/systm.h at the last 1999-08-21 22:10:49 +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 SMBus support for the Intel PIIX4 power management unit. See smbus(4), 1999-01-24 18:13:31 +00:00
isp_pci.c Cast pointers to uintptr_t instead of casting them to u_long, and/or vice 1999-08-24 00:56:50 +00:00
locate.pl
meteor_reg.h Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +00:00
meteor.c Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +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 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 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 Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +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 Slightly sanitize the isa/eisa bridge detection. The pci->eisa bridge 1999-08-22 19:10:39 +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 Reset the UHCI controller when the device comes back from suspend. 1999-08-23 21:00:08 +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 Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +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