From: "Kok, Auke" <auke-jan.h.kok@intel.com>
To: Grant Grundler <grundler@parisc-linux.org>
Cc: linux-kernel@vger.kernel.org, linux-pci@atrey.karlin.mff.cuni.cz,
gregkh@suse.de
Subject: Re: [PATCH 1/2] [RFC] PCI: read revision ID by default
Date: Sat, 09 Jun 2007 12:48:47 -0700 [thread overview]
Message-ID: <466B041F.3030002@intel.com> (raw)
In-Reply-To: <20070609065953.GA1747@colo.lackof.org>
Grant Grundler wrote:
> On Fri, Jun 08, 2007 at 03:46:30PM -0700, Auke Kok wrote:
>> Currently there are 97 occurrences where drivers need the pci
>> revision ID. We can do this once for all devices. Even the pci
>> subsystem needs the revision several times for quirks. The extra
>> u8 member pads out nicely in the pci_dev struct.
>
> Good idea. I always wondered why we read the invariants so often
> in the code.
>
>> Signed-off-by: Auke Kok <auke-jan.h.kok@intel.com>
>> ---
>>
>> drivers/pci/probe.c | 3 +++
>> include/linux/pci.h | 1 +
>> 2 files changed, 4 insertions(+), 0 deletions(-)
>>
>> diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
>> index e48fcf0..0fdb71d 100644
>> --- a/drivers/pci/probe.c
>> +++ b/drivers/pci/probe.c
>> @@ -918,6 +918,9 @@ pci_scan_device(struct pci_bus *bus, int devfn)
>> dev->cfg_size = pci_cfg_space_size(dev);
>> dev->error_state = pci_channel_io_normal;
>>
>> + /* read the PCI revision: 1 byte */
>> + pci_read_config_byte(dev, PCI_REVISION_ID, &dev->revision);
>
> probe.c:pci_setup_device() is also reading this byte but discards it:
> pci_read_config_dword(dev, PCI_CLASS_REVISION, &class);
> class >>= 8; /* upper 3 bytes */
> dev->class = class;
>
> Can you use "class & 0xff"? Or is pci_setup_device() too late?
> Or can you read the whole 32-bits in pci_scan_device() and remove
> the pci_read_config() in pci_setup_device()?
no, pci_setup_device() is just called right after the location where I read the
REVISION_ID. I'll remove the read and put the dev->revision right after where we
read the class dword.
Auke
prev parent reply other threads:[~2007-06-09 19:49 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-06-08 22:46 [PATCH 1/2] [RFC] PCI: read revision ID by default Auke Kok
2007-06-08 22:46 ` [PATCH 2/2] [RFC] PCI: Change all drivers to use pci_device->revision Auke Kok
2007-06-11 15:19 ` Dave Jones
2007-06-09 6:59 ` [PATCH 1/2] [RFC] PCI: read revision ID by default Grant Grundler
2007-06-09 8:02 ` David Miller
2007-06-09 19:31 ` Kok, Auke
2007-06-09 19:48 ` Kok, Auke [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=466B041F.3030002@intel.com \
--to=auke-jan.h.kok@intel.com \
--cc=gregkh@suse.de \
--cc=grundler@parisc-linux.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@atrey.karlin.mff.cuni.cz \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.