summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYu Watanabe <watanabe.yu+github@gmail.com>2022-09-19 00:32:44 +0200
committerYu Watanabe <watanabe.yu+github@gmail.com>2022-09-19 11:04:13 +0200
commitc42033e7bea6d1eda2391f91b7ff78fcbd9ce948 (patch)
tree542a669e09365351d8ca031c978fcf36aa2d84b7
parentsd-device: re-implement device_sysattrs_read_all() without recursion (diff)
downloadsystemd-c42033e7bea6d1eda2391f91b7ff78fcbd9ce948.tar.xz
systemd-c42033e7bea6d1eda2391f91b7ff78fcbd9ce948.zip
udev: use faccessat()
No functional changes, just refactoring.
-rw-r--r--src/udev/udev-builtin-net_id.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/src/udev/udev-builtin-net_id.c b/src/udev/udev-builtin-net_id.c
index c1ad190ca8..377ea60722 100644
--- a/src/udev/udev-builtin-net_id.c
+++ b/src/udev/udev-builtin-net_id.c
@@ -285,9 +285,9 @@ static bool is_pci_bridge(sd_device *dev) {
return b;
}
-static int parse_hotplug_slot_from_function_id(sd_device *dev, const char *slots, uint32_t *ret) {
+static int parse_hotplug_slot_from_function_id(sd_device *dev, int slots_dirfd, uint32_t *ret) {
uint64_t function_id;
- char path[PATH_MAX];
+ char filename[NAME_MAX+1];
const char *attr;
int r;
@@ -300,7 +300,7 @@ static int parse_hotplug_slot_from_function_id(sd_device *dev, const char *slots
* between PCI function and its hotplug slot. */
assert(dev);
- assert(slots);
+ assert(slots_dirfd >= 0);
assert(ret);
if (!naming_scheme_has(NAMING_SLOT_FUNCTION_ID))
@@ -318,12 +318,12 @@ static int parse_hotplug_slot_from_function_id(sd_device *dev, const char *slots
"Invalid function id (0x%"PRIx64"), ignoring.",
function_id);
- if (!snprintf_ok(path, sizeof path, "%s/%08"PRIx64, slots, function_id))
+ if (!snprintf_ok(filename, sizeof(filename), "%08"PRIx64, function_id))
return log_device_debug_errno(dev, SYNTHETIC_ERRNO(ENAMETOOLONG),
"PCI slot path is too long, ignoring.");
- if (access(path, F_OK) < 0)
- return log_device_debug_errno(dev, errno, "Cannot access %s, ignoring: %m", path);
+ if (faccessat(slots_dirfd, filename, F_OK, 0) < 0)
+ return log_device_debug_errno(dev, errno, "Cannot access %s under pci slots, ignoring: %m", filename);
*ret = (uint32_t) function_id;
return 1;
@@ -423,7 +423,7 @@ static int dev_pci_slot(sd_device *dev, const LinkInfo *info, NetNames *names) {
hotplug_slot_dev = names->pcidev;
while (hotplug_slot_dev) {
- r = parse_hotplug_slot_from_function_id(hotplug_slot_dev, slots, &hotplug_slot);
+ r = parse_hotplug_slot_from_function_id(hotplug_slot_dev, dirfd(dir), &hotplug_slot);
if (r < 0)
return 0;
if (r > 0) {