Re: [libvirt PATCH v5 1/7] Add a PCI/PCIe device VPD Parser

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, Oct 1, 2021 at 7:49 PM Daniel P. Berrangé <berrange@xxxxxxxxxx> wrote:

> > A GTree is used as a data structure in order to maintain key ordering
> > which will be important in XML to XML tests later.
>
> Now, I've learnt a bit more about VPD and considering my comments on
> the XML format in the last patch, I think this use of GTree is
> unduly opaque and overkill
>
> I think we should be representing the data we're extracting as
> plan struct fields, in the same way that we handle SMBIOS in the
> virsysinfo.h file....
>
> ....I feel like all of this can be reduced down to just a couple
> of public structs and a single method:
>
>     typedef struct virPCIVPDResourceCustom virPCIVPDResourceCustom;
>     struct virPCIVPDResourceCustom {
>       char idx;
>       char *value;
>     };
>
>     typedef struct virPCIVPDResourceRO virPCIVPDResourceRO;
>     struct virPCIVPDResourceRO {
>       char *part_numer;
>       char *change_level;
>       char *fabric_geography;
>       char *location;
>       char *manufcatur_id;
>       char *pci_geography;
>       char *serial_number;
>       size_t nvendor_specific;
>       virPCIVPDResourceCustom *vendor_specific;
>     };
>
>
>     typedef struct virPCIVPDResourceRW virPCIVPDResourceRW;
>     struct virPCIVPDResourceRW {
>       char *asset_tag;
>       size_t nvendor_specific;
>       virPCIVPDResourceCustom *vendor_specific;
>       size_t nsystem_specific;
>       virPCIVPDResourceCustom *system_specific;
>     };
>
>     typedef struct virPCIVPDResource virPCIVPDResource;
>     struct virPCIVPDResource {
>       char *name;
>       virPCIVPDResourceRO *ro;
>       virPCIVPDResourceRW *rw;
>     }
>
>     virPCIVPDResource *virPCIVPDParse(int vpdFileFd);
>     void virPCIVPDResourceFree(virPCIVPDResource *res);
>     G_DEFINE_AUTOPTR_CLEANUP_FUNC(virPCIVPDResource, virPCIVPDResourceFree);
>

Ack, I can rework it as you describe.

There will be a bit more work to do in XML serialization and
deserialization code to map struct fields to keyword names and vice
versa but I'll see what I can come up with.

My original goal with using Glib data structures was to use standard
iteration, insertion and lookup operations and also simplify automatic
cleanup implementation. On the other hand, there are some specifics of
working with them as my workaround for a bug with derived types shows.





[Index of Archives]     [Virt Tools]     [Libvirt Users]     [Lib OS Info]     [Fedora Users]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite News]     [KDE Users]     [Fedora Tools]

  Powered by Linux