[dpdk-dev] [RFC PATCH 5/5] virtio: Extend virtio-net PMD to support container environment
Tetsuya Mukawa
mukawa at igel.co.jp
Thu Jan 28 03:47:59 CET 2016
On 2016/01/28 1:45, Xie, Huawei wrote:
> On 1/21/2016 7:09 PM, Tetsuya Mukawa wrote:
>> +qtest_find_pci_device(struct qtest_session *s, uint16_t bus, uint8_t device)
>> +{
>> + struct qtest_pci_device *dev;
>> + uint32_t val;
>> +
>> + val = qtest_pci_inl(s, bus, device, 0, 0);
>> + TAILQ_FOREACH(dev, &s->head, next) {
>> + if (val == ((uint32_t)dev->device_id << 16 | dev->vendor_id)) {
>> + dev->bus_addr = bus;
>> + dev->device_addr = device;
>> + return;
>> + }
>> +
>> + }
>> +}
>> +
>> +static int
>> +qtest_init_pci_devices(struct qtest_session *s)
>> +{
>> + struct qtest_pci_device *dev;
>> + uint16_t bus;
>> + uint8_t device;
>> + int ret;
>> +
>> + /* Find devices */
>> + bus = 0;
>> + do {
>> + device = 0;
>> + do {
>> + qtest_find_pci_device(s, bus, device);
>> + } while (device++ != NB_DEVICE - 1);
>> + } while (bus++ != NB_BUS - 1);
> Seems this scan of all the pci devices is very time consuming operation,
> and each scan involves socket communication.
> Do you measure how long it takes to do the pci devices initialization?
I measured it, and seems it takes 0.35 seconds in my environment.
This will be done only once when the port is initialized. Probably it's
not so heady.
Tetsuya
More information about the dev
mailing list