freebsd-nq/sys/pci
Bill Paul 0f41c63996 Change PN_RXLEN from 1518 bytes to 1536 bytes. The chip always DMAs data
in 4 byte chunks. It turns out that with the 82c169C on the Netgear
FA-310TX Rev D2, if you tell the chip you have reserved a buffer of 1518
bytes, it will actually treat it as 1516 bytes since 1518 is divisible
by four. Consequently, a packet of 1514 bytes will always end up consuming
two buffers: the last coupleof bytes will spill over into the next
descriptor. This causes the pn_rx_bug_war() routine to trip unnecessarily.

I'm not sure if the 82c169B or 82c168 chips behave the same way; I'll
have to check them. In any case, this change should work just as well
with them. Note that the FA-310TX Rev D2 also has a Broadcom PHY
instead of a Level One LXT970 PHY, however this shouldn't make any
difference as far as the driver is concerned.

This change also allows me to do a way with one rounding overation in
pn_rx-buf_war().
1999-08-24 03:19:45 +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
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
cy_pcireg.h
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
es1370.c
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
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
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
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 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
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 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 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 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
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
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 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
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 Convert DEVFS hooks in (most) drivers to make_dev(). 1999-08-23 20:59:21 +00:00
pcic_p.c
pcic_p.h
pcireg.h
pcisupport.c Slightly sanitize the isa/eisa bridge detection. The pci->eisa bridge 1999-08-22 19:10:39 +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 Reset the UHCI controller when the device comes back from suspend. 1999-08-23 21:00:08 +00:00
xmaciireg.h
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