Michael Brown
|
9eac705dd2
|
Added a generalised ISA device-probing mechanism.
|
2005-04-14 18:46:43 +00:00 |
|
Michael Brown
|
e5b537fed0
|
name should be const
|
2005-04-14 17:52:27 +00:00 |
|
Michael Brown
|
cee678de7c
|
Fixed up automatic modifications by hand.
|
2005-04-14 15:09:28 +00:00 |
|
Michael Brown
|
2c60617836
|
Automatically modified by
perl -pi -0777 -e 's/\s*?if\s*\(\s*!\s*find_pci_device.*?,\s*\&(\w+)\s*\)\s*\)\s*return\s*0;(.*BOOT_DRIVER\s*\(.*?,)(.*?\))/$2 find_pci_boot_device, $1,$3/sm' *.c
|
2005-04-14 15:00:05 +00:00 |
|
Michael Brown
|
393969a3f8
|
Fix up the automatic modifications.
|
2005-04-14 14:59:04 +00:00 |
|
Michael Brown
|
476dff5bb7
|
Made amenable to automatic update.
|
2005-04-14 14:49:32 +00:00 |
|
Michael Brown
|
cbd5d4f849
|
This is the only driver that has a genuine reason to call
find_pci_device() directly.
|
2005-04-14 14:48:07 +00:00 |
|
Michael Brown
|
963dbefb51
|
Automatically updated using
perl -pi -0777 -e 's/(_probe\s*\(\s*struct\s+dev.*?)(\s*\)\s*{.*?$)\s*struct pci_device.*?=\s*pci_device \( dev \);$/${1}, struct pci_device *pci${2}/ms' *.c
sis900 excluded from update
|
2005-04-14 14:44:33 +00:00 |
|
Michael Brown
|
72fe23a76e
|
Updated to new device API.
|
2005-04-14 14:31:11 +00:00 |
|
Michael Brown
|
2e309f9eec
|
Fix BOOT_DRIVER to assign unique and meaningful name to structure.
|
2005-04-14 14:30:03 +00:00 |
|
Michael Brown
|
9183f2412e
|
bus header files must include dev.h to get struct dev.
|
2005-04-14 14:26:28 +00:00 |
|
Michael Brown
|
e0a8ee385e
|
Updated to current device API.
|
2005-04-14 13:49:58 +00:00 |
|
Michael Brown
|
104880ca19
|
Tweak API to allow separation of bus-scanning and device-probing logic.
|
2005-04-14 13:44:07 +00:00 |
|
Michael Brown
|
ce8dea0dff
|
Separate out bus-scanning and device-probing logic.
|
2005-04-14 13:33:03 +00:00 |
|
Michael Brown
|
4c0d5a0b71
|
Split 3c509.c into 3c509.9 and 3c529.c, with shared code in 3c5x9.c.
Probe mechanisms now use standard EISA and MCA bus methods, with 3c509.c
defining a custom ISA bus to handle the 3c509 contention resolution logic.
|
2005-04-14 12:23:12 +00:00 |
|
Michael Brown
|
1f26be34b8
|
Allow for multiple BOOT_DRIVER()s in the same file, provided that they
have different probe functions.
|
2005-04-14 12:02:19 +00:00 |
|
Michael Brown
|
44c7cc8c12
|
Standardised debug mechanism in place now.
|
2005-04-14 11:55:57 +00:00 |
|
Michael Brown
|
e44e5c7247
|
compiler.h is now always included on the command line.
|
2005-04-14 11:50:26 +00:00 |
|
Michael Brown
|
bc85cf756d
|
We need the ISA product ID mask available separately for 3c509.c.
|
2005-04-14 11:47:30 +00:00 |
|
Michael Brown
|
305daba48a
|
Always include compiler.h.
Add bin/%.rebuild rule to quickly force a rebuild of any file.
Add bin/%.o.dbg rule to build a debugging-enabled version of the object.
|
2005-04-14 11:45:37 +00:00 |
|
Michael Brown
|
dcd573afcb
|
Automatically create DBG() macro based on debug_<object> macro.
|
2005-04-14 11:35:45 +00:00 |
|
Michael Brown
|
75d864432c
|
Use the magic of common symbols to allow struct dev to effectively grow at
link time to accommodate whatever bus objects are included.
|
2005-04-14 10:10:54 +00:00 |
|
Michael Brown
|
0dc98309b2
|
Stripped references to variables in C code.
|
2005-04-13 13:48:26 +00:00 |
|
Michael Brown
|
e294a1ddce
|
EISA support now provided by eisa.c
MCA support now provided by mca.c
|
2005-04-13 13:06:56 +00:00 |
|
Michael Brown
|
200b39a645
|
Extraced from 3c509.c
|
2005-04-13 12:45:38 +00:00 |
|
Michael Brown
|
a4f1a058a4
|
Add EISA as a bus type.
|
2005-04-13 12:20:59 +00:00 |
|
Michael Brown
|
4ae83f28f2
|
Don't use htons, for compatibility with PCI :(
|
2005-04-13 12:15:14 +00:00 |
|
Michael Brown
|
4ecbc63296
|
Use __bswap_16, since we're not dealing with quantities to go onto the network.
|
2005-04-13 12:11:21 +00:00 |
|
Michael Brown
|
5b8e549c83
|
htons was used in ISAPnP code just due to ISAPnP storing bytes in
reverse order.
|
2005-04-13 12:06:33 +00:00 |
|
Michael Brown
|
9711f50e20
|
Created separate isa_ids.h file and a utility function to print out ISA
IDs in a human-readable format.
|
2005-04-13 12:01:44 +00:00 |
|
Michael Brown
|
ac1c0a753d
|
Add MCA devices
|
2005-04-13 03:00:50 +00:00 |
|
Michael Brown
|
677cda3263
|
Minor fixups
|
2005-04-13 03:00:30 +00:00 |
|
Michael Brown
|
1aee4e8001
|
Extracted from 3c509.c
|
2005-04-13 02:59:13 +00:00 |
|
Michael Brown
|
e27ebad4b2
|
Whoops
|
2005-04-13 02:05:43 +00:00 |
|
Michael Brown
|
7cc6366a84
|
Finished by hand
|
2005-04-13 02:02:08 +00:00 |
|
Michael Brown
|
951e305081
|
Finished by hand
|
2005-04-13 01:45:20 +00:00 |
|
Michael Brown
|
f39cc6d978
|
Finished by hand
|
2005-04-13 01:31:44 +00:00 |
|
Michael Brown
|
f16ac2d87e
|
Fix type of dummy_irq()
|
2005-04-13 01:28:43 +00:00 |
|
Michael Brown
|
9848135950
|
Finished by hand
|
2005-04-13 01:01:33 +00:00 |
|
Michael Brown
|
3616de915e
|
Hand-finished
|
2005-04-13 00:21:59 +00:00 |
|
Michael Brown
|
6e8878c1fa
|
Avoid compiler warnings.
|
2005-04-13 00:19:01 +00:00 |
|
Michael Brown
|
266dae4034
|
Use NIC's connect method.
|
2005-04-13 00:18:35 +00:00 |
|
Michael Brown
|
17d69d8930
|
Add mbps and duplex to struct nic, since some drivers (e.g. rtl8139)
can fill them in.
|
2005-04-13 00:16:42 +00:00 |
|
Michael Brown
|
28590d718b
|
Hand-finished
|
2005-04-13 00:15:45 +00:00 |
|
Michael Brown
|
91e46ed588
|
Automatically updated using
perl -pi -0777 -e 's/^(\s*)dev->disable(\s*)=\s*(\w+)_disable;\s*nic->poll\s*=\s*(\w+);\s*nic->transmit\s*=\s*(\w+);\s*nic->irq\s*=\s*(\w+);/static struct nic_operations ${3}_operations;\nstatic struct nic_operations ${3}_operations = {\n\t.connect\t= dummy_connect,\n\t.poll\t\t= $4,\n\t.transmit\t= $5,\n\t.irq\t\t= $6,\n\t.disable\t= ${3}_disable,\n};${1}nic->nic_op\t= &${3}_operations;/msg' *.c
|
2005-04-13 00:02:40 +00:00 |
|
Michael Brown
|
d9c64c9422
|
Manual tweaks to get all drivers to follow the "disable, poll, transmit,
irq" pattern.
|
2005-04-12 23:47:52 +00:00 |
|
Michael Brown
|
881023e9ca
|
Automatically updated using
perl -pi -e 's/(_probe\s*\(\s*struct )dev \*.*?(\s*\);)/${1}dev *dev$2/' *.c
perl -pi -e 's/(_disable\s*\(\s*struct )dev \*.*?(\s*\);)/${1}nic *nic$2/' *.c
|
2005-04-12 23:39:16 +00:00 |
|
Michael Brown
|
c87ba23399
|
Automatically updated using
perl -pi -0777 -e 's/_disable\s*\(\s*struct dev \*dev\s*\)\s*{\s*struct nic \*nic.*?$/_disable ( struct nic *nic ) {/ms' *.c
perl -pi -0777 -e 's/_disable\s*\(\s*struct dev \*dev(\s*__unused)?\)\s*{/_disable ( struct nic *nic$1 ) {/ms' *.c
|
2005-04-12 23:31:37 +00:00 |
|
Michael Brown
|
bd9ae7cc70
|
Automatically updated using
perl -pi -0777 -e 's/_probe\s*\(\s*struct dev \*dev,\s*struct pci_device \*(\w+?)\s*\)\s*{(\s*)struct nic \*nic.*?$/_probe ( struct dev *dev ) {\n${2}struct nic *nic = nic_device ( dev );\n${2}struct pci_device *$1 = pci_device ( dev );/ms' *.c
|
2005-04-12 23:24:39 +00:00 |
|
Michael Brown
|
35e6f3e58a
|
Minor regexp tweaks to catch degenerate cases.
|
2005-04-12 23:13:54 +00:00 |
|