• D
    libqos: Change PCI accessors to take opaque BAR handle · b4ba67d9
    David Gibson 提交于
    The usual use model for the libqos PCI functions is to map a specific PCI
    BAR using qpci_iomap() then pass the returned token into IO accessor
    functions.  This, and the fact that iomap() returns a (void *) which
    actually contains a PCI space address, kind of suggests that the return
    value from iomap is supposed to be an opaque token.
    
    ..except that the callers expect to be able to add offsets to it.  Which
    also assumes the compiler will support pointer arithmetic on a (void *),
    and treat it as working with byte offsets.
    
    To clarify this situation change iomap() and the IO accessors to take
    a definitely opaque BAR handle (enforced with a wrapper struct) along with
    an offset within the BAR.  This changes both the functions and all the
    callers.
    
    There were a number of places that checked if iomap() returned non-NULL,
    and or initialized it to NULL before hand.  Since iomap() already assert()s
    if it fails to map the BAR, these tests were mostly pointless and are
    removed.
    Signed-off-by: NDavid Gibson <david@gibson.dropbear.id.au>
    Reviewed-by: NGreg Kurz <groug@kaod.org>
    b4ba67d9
ahci.h 20.8 KB