mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-23 14:13:58 +08:00
d29693bf10
Expose example and tool source files in the Documentation/ directory in their own files instead of being buried (almost hidden) in readme/txt files. This will make them more visible/usable to users who may need to use them, to developers who may need to test with them, and to janitors who would update them if they were more visible. Also, if any of these possibly should not be in the kernel tree at all, it will be clearer that they are here and we can discuss if they should be removed. Signed-off-by: Randy Dunlap <rdunlap@xenotime.net> Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
34 lines
1.3 KiB
Plaintext
34 lines
1.3 KiB
Plaintext
Matching of PCMCIA devices to drivers is done using one or more of the
|
|
following criteria:
|
|
|
|
- manufactor ID
|
|
- card ID
|
|
- product ID strings _and_ hashes of these strings
|
|
- function ID
|
|
- device function (actual and pseudo)
|
|
|
|
You should use the helpers in include/pcmcia/device_id.h for generating the
|
|
struct pcmcia_device_id[] entries which match devices to drivers.
|
|
|
|
If you want to match product ID strings, you also need to pass the crc32
|
|
hashes of the string to the macro, e.g. if you want to match the product ID
|
|
string 1, you need to use
|
|
|
|
PCMCIA_DEVICE_PROD_ID1("some_string", 0x(hash_of_some_string)),
|
|
|
|
If the hash is incorrect, the kernel will inform you about this in "dmesg"
|
|
upon module initialization, and tell you of the correct hash.
|
|
|
|
You can determine the hash of the product ID strings by catting the file
|
|
"modalias" in the sysfs directory of the PCMCIA device. It generates a string
|
|
in the following form:
|
|
pcmcia:m0149cC1ABf06pfn00fn00pa725B842DpbF1EFEE84pc0877B627pd00000000
|
|
|
|
The hex value after "pa" is the hash of product ID string 1, after "pb" for
|
|
string 2 and so on.
|
|
|
|
Alternatively, you can use crc32hash (see Documentation/pcmcia/crc32hash.c)
|
|
to determine the crc32 hash. Simply pass the string you want to evaluate
|
|
as argument to this program, e.g.:
|
|
$ ./crc32hash "Dual Speed"
|