bus/pci: fix size of driver name buffer
Variable dri_name is a pointer and it is incorrect to use its
size as the buffer size. Caller knows the buffer size and
it is safer to pass it explicitly.
Fixes: fe5f777b53
("bus/pci: replace strncpy by strlcpy")
Cc: stable@dpdk.org
Signed-off-by: Andy Green <andy@warmcat.com>
Reviewed-by: Andrew Rybchenko <arybchenko@solarflare.com>
This commit is contained in:
parent
ff75dd7d65
commit
52f711f7b8
@ -33,7 +33,8 @@
|
||||
extern struct rte_pci_bus rte_pci_bus;
|
||||
|
||||
static int
|
||||
pci_get_kernel_driver_by_path(const char *filename, char *dri_name)
|
||||
pci_get_kernel_driver_by_path(const char *filename, char *dri_name,
|
||||
size_t len)
|
||||
{
|
||||
int count;
|
||||
char path[PATH_MAX];
|
||||
@ -54,7 +55,7 @@ pci_get_kernel_driver_by_path(const char *filename, char *dri_name)
|
||||
|
||||
name = strrchr(path, '/');
|
||||
if (name) {
|
||||
strlcpy(dri_name, name + 1, sizeof(dri_name));
|
||||
strlcpy(dri_name, name + 1, len);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -314,7 +315,7 @@ pci_scan_one(const char *dirname, const struct rte_pci_addr *addr)
|
||||
|
||||
/* parse driver */
|
||||
snprintf(filename, sizeof(filename), "%s/driver", dirname);
|
||||
ret = pci_get_kernel_driver_by_path(filename, driver);
|
||||
ret = pci_get_kernel_driver_by_path(filename, driver, sizeof(driver));
|
||||
if (ret < 0) {
|
||||
RTE_LOG(ERR, EAL, "Fail to get kernel driver\n");
|
||||
free(dev);
|
||||
|
Loading…
Reference in New Issue
Block a user