2010-05-07 7 views
11

I primi campi di "cat/proc/bus/pci/devices" sono comprensibili.Come interpretare i contenuti di/proc/bus/pci/devices?

Campo 1 - BusDevFunc
Campo 2 - Vendita Id + ID dispositivo
campo 3 - Linea interrupt
Campo 4 - BAR 0
e il resto dei registri BAR (0 - 5) dopo.

Dopo aver stampato i registri BAR, quali sono gli altri campi? In particolare, quali registri dello spazio di configurazione PCI (offset) vengono stampati?

+0

fare questa ServerFault –

+0

ho http://serverfault.com/questions/139670/how-to-interpret-the-contents-of-proc-bus-pci-devices questo dovrebbe essere chiuso fuori? – vivekian2

+0

È necessario rimuovere completamente la domanda raddoppiata da serverfault.com; in seguito sentiti libero di contrassegnare questa domanda qui per essere spostata su serverfault. (Come incentivo, l'ho downvoted lì. - Quando rimuovi il tuo q/a su serverfault, recuperi la reputazione.) –

risposta

15

Questo è il codice corrispondente nel kernel:

static int show_device(struct seq_file *m, void *v) 
{ 
    const struct pci_dev *dev = v; 
    const struct pci_driver *drv; 
    int i; 

    if (dev == NULL) 
     return 0; 

    drv = pci_dev_driver(dev); 
    seq_printf(m, "%02x%02x\t%04x%04x\t%x", 
      dev->bus->number, 
      dev->devfn, 
      dev->vendor, 
      dev->device, 
      dev->irq); 
    /* Here should be 7 and not PCI_NUM_RESOURCES as we need to preserve compatibility */ 
    for (i=0; i<7; i++) { 
     resource_size_t start, end; 
     pci_resource_to_user(dev, i, &dev->resource[i], &start, &end); 
     seq_printf(m, "\t%16llx", 
      (unsigned long long)(start | 
      (dev->resource[i].flags & PCI_REGION_FLAG_MASK))); 
    } 
    for (i=0; i<7; i++) { 
     resource_size_t start, end; 
     pci_resource_to_user(dev, i, &dev->resource[i], &start, &end); 
     seq_printf(m, "\t%16llx", 
      dev->resource[i].start < dev->resource[i].end ? 
      (unsigned long long)(end - start) + 1 : 0); 
    } 
    seq_putc(m, '\t'); 
    if (drv) 
     seq_printf(m, "%s", drv->name); 
    seq_putc(m, '\n'); 
    return 0; 
} 

Dopo l'IRQ, risulta essere gli indirizzi iniziali in combinazione con le bandiere dei primi 6 regioni risorsa, seguito dalle lunghezze di tali regioni risorse , seguito dal nome del driver che ha rivendicato il dispositivo.

Problemi correlati