mirror of
https://github.com/morgan9e/systemd
synced 2026-04-14 08:25:20 +09:00
shared/device-nodes: add devnode_same
This commit is contained in:
@@ -3,8 +3,10 @@
|
||||
#include <errno.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <sys/stat.h>
|
||||
|
||||
#include "device-nodes.h"
|
||||
#include "path-util.h"
|
||||
#include "string-util.h"
|
||||
#include "utf8.h"
|
||||
|
||||
@@ -58,3 +60,28 @@ int encode_devnode_name(const char *str, char *str_enc, size_t len) {
|
||||
str_enc[j] = '\0';
|
||||
return 0;
|
||||
}
|
||||
|
||||
int devnode_same(const char *a, const char *b) {
|
||||
struct stat sa, sb;
|
||||
|
||||
assert(a);
|
||||
assert(b);
|
||||
|
||||
if (!valid_device_node_path(a) || !valid_device_node_path(b))
|
||||
return -EINVAL;
|
||||
|
||||
if (stat(a, &sa) < 0)
|
||||
return -errno;
|
||||
if (stat(b, &sb) < 0)
|
||||
return -errno;
|
||||
|
||||
if (!S_ISBLK(sa.st_mode) && !S_ISCHR(sa.st_mode))
|
||||
return -ENODEV;
|
||||
if (!S_ISBLK(sb.st_mode) && !S_ISCHR(sb.st_mode))
|
||||
return -ENODEV;
|
||||
|
||||
if (((sa.st_mode ^ sb.st_mode) & S_IFMT) != 0) /* both inode same device node type? */
|
||||
return false;
|
||||
|
||||
return sa.st_rdev == sb.st_rdev;
|
||||
}
|
||||
|
||||
@@ -5,3 +5,5 @@
|
||||
|
||||
int encode_devnode_name(const char *str, char *str_enc, size_t len);
|
||||
int allow_listed_char_for_devnode(char c, const char *additional);
|
||||
|
||||
int devnode_same(const char *a, const char *b);
|
||||
|
||||
Reference in New Issue
Block a user