@Bandicoot Si le périphérique n'est pas connectable à chaud, la fonctionnalité de probe() peut être placée dans la méthode init(), ce qui réduira l'empreinte mémoire du pilote au moment de l'exécution. P.S lien
Pour un périphérique "plate-forme", la fonction probe est invoquée lorsqu'un périphérique plate-forme est enregistré et que son nom correspond au nom spécifié dans le pilote du périphérique. P.S lien
La fonction i2c_detect sonde l'adaptateur I2C, à la recherche des différentes adresses spécifiées dans la structure addr_data. Si un périphérique est trouvé, la fonction chip_detect est alors appelée. P.S lien .
Un lien qui va sûrement lever vos doutes. P.S lien
Dans le noyau 2.4.29, je peux vous montrer comment la sonde se produit ? Veuillez voir ci-dessous (Nom du fichier : drivers/acorn/char/pcf8583.c )
static struct i2c_driver pcf8583_driver = {
name: "PCF8583",
id: I2C_DRIVERID_PCF8583,
flags: I2C_DF_NOTIFY,
attach_adapter: pcf8583_probe, /* This will be called from i2c-core.c P.S see below function i2c_add_driver()*/
detach_client: pcf8583_detach,
command: pcf8583_command
} ;
Nom du fichier : drivers/i2c/i2c-core.c
int i2c_add_driver(struct i2c_driver *driver)
{
........................
........................
/* now look for instances of driver on our adapters
*/
if (driver->flags& (I2C_DF_NOTIFY|I2C_DF_DUMMY)) {
for (i=0;i<I2C_ADAP_MAX;i++)
if (adapters[i]!=NULL)
/* Ignore errors */
driver->attach_adapter(adapters[i]); /*This is a location from where probe is called. Pointer **driver** is of type **pcf8583_driver** which you have passed into this function*/
}
ADAP_UNLOCK();
return 0;
}
Quelques liens importants :
1) http://www.slideshare.net/varunmahajan06/i2c-subsystem-in-linux2624
2) http://www.programering.com/a/MjNwcTMwATM.html
3) http://www.linuxjournal.com/article/6717
4) http://www.developermemo.com/2943157/
5) http://free-electrons.com/doc/kernel-architecture.pdf
6) http://www.techques.com/question/1-3014627/Probe-problem-when-writing-a-I2C-device-driver
Dans le PCI pour kernel-2.4.29, il est appelé lorsque le vendeur et l'identifiant du périphérique sont identifiés. Le pilote du bus PCI le fait pour vous. Veuillez voir le code ci-dessous :
Nom du fichier : drivers/pci/pci.c
static int pci_announce_device(struct pci_driver *drv, struct pci_dev *dev)
{
const struct pci_device_id *id;
int ret = 0;
if (drv->id_table) {
id = pci_match_device(drv->id_table, dev); /* check for device presence*/
if (!id) {
ret = 0;
goto out;
}
} else
id = NULL;
dev_probe_lock();
if (drv->probe(dev, id) >= 0) { /* This is a location from where probe is called*/
dev->driver = drv;
ret = 1;
}
dev_probe_unlock();
out:
return ret;
}