Windows System Software -- Consulting, Training, Development -- Unique Expertise, Guaranteed Results

Home NTDEV
Before Posting...
Please check out the Community Guidelines in the Announcements and Administration Category.

More Info on Driver Writing and Debugging


The free OSR Learning Library has more than 50 articles on a wide variety of topics about writing and debugging device drivers and Minifilters. From introductory level to advanced. All the articles have been recently reviewed and updated, and are written using the clear and definitive style you've come to expect from OSR over the years.


Check out The OSR Learning Library at: https://www.osr.com/osr-learning-library/


PCI BUS device filter driver

rajgobirajgobi Member Posts: 1

Hi, I'm looking for adding the filter to modify the config space access. I tried to add the filter driver (tried checking with lower and upper) till the first one listed with the !pcitree.
But I ending up with 2 cases:
1. Upper/Lower filter driver is always loading after the actual PCI device object created
-- Please confirm, is that the filter drivers would be loaded actual device driver?
2. Before the first PDO been created (top one from the list !pcitree), when I tried to check with the config space of my device using !pci 121 able to notice that config space is already available through windbg
-- How the config space of the device is available with !pci command even before first PDO with the !pcitree been created?
-- How to capture the first config space read access? so that I can get opportunity to modify the values

Comments

  • Tim_RobertsTim_Roberts Member - All Emails Posts: 13,818

    What kind of filtering are you hoping to do? I suspect you have some major misunderstandings of how things actually work.

    The configuration space for a PCI device is available as soon as power is applied. That's an attribute of the hardware. The operating system is not involved.

    Driver stacks are built from the bottom up. PDO, then lower filters, then FDO, then upper filters.

    The PCI bus driver reads the configuration space directly, using one of several access methods. These are hardware operations. There is no way to get a filter driver involved.

    Tim Roberts, [email protected]
    Providenza & Boekelheide, Inc.

Sign In or Register to comment.

Howdy, Stranger!

It looks like you're new here. If you want to get involved, click one of these buttons!

Upcoming OSR Seminars
OSR has suspended in-person seminars due to the Covid-19 outbreak. But, don't miss your training! Attend via the internet instead!
Writing WDF Drivers 7 Dec 2020 LIVE ONLINE
Internals & Software Drivers 25 Jan 2021 LIVE ONLINE
Developing Minifilters 8 March 2021 LIVE ONLINE