On Thu, Sep 17, 2015 at 01:17:12AM +0900, Taku Izumi wrote:

> +struct pci2phy_map {
> +     struct list_head list;
> +     int segment;
> +     int pbus_to_physid[256];
> +};

> +struct pci2phy_map *__find_pci2phy_map(int segment)
> +{
> +     struct pci2phy_map *map, *alloc = NULL;
> +
> +     lockdep_assert_held(&pci2phy_map_lock);
> +
> +lookup:
> +     list_for_each_entry(map, &pci2phy_map_head, list) {
> +             if (map->segment == segment)
> +                     goto end;
> +     }
> +
> +     if (!alloc) {
> +             raw_spin_unlock(&pci2phy_map_lock);
> +             alloc = kmalloc(sizeof(struct pci2phy_map), GFP_KERNEL);

Do we want kzalloc() ? we unconditionally initialize the list and
segment thingies, but that array is not initialized here. Or is there a
better/safer value to initialize that array with?

Looking at uncore_pcibus_to_physid(), -1 might be a good value to use.

> +             raw_spin_lock(&pci2phy_map_lock);
> +
> +             if (!alloc)
> +                     return NULL;
> +
> +             goto lookup;
> +     }
> +
> +     map = alloc;
> +     alloc = NULL;
> +     map->segment = segment;
> +     list_add_tail(&map->list, &pci2phy_map_head);
> +
> +end:
> +     kfree(alloc);
> +     return map;
> +}

Other than that I think the patch looks OK now.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to