1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-09 01:18:39 +03:00

Configuration-time option for setting uid/gid/mode for /dev/mapper nodes.

This commit is contained in:
Alasdair Kergon 2005-01-05 22:00:40 +00:00
parent 4661ab1179
commit 6eebc4a620
6 changed files with 52 additions and 15 deletions

View File

@ -1,5 +1,6 @@
Version 1.00.20 - Version 1.00.20 -
============================= =============================
Configuration-time option for setting uid/gid/mode for /dev/mapper nodes.
Update kernel patches for 2.4.27/2.4.28-pre-4 (includes minor fixes). Update kernel patches for 2.4.27/2.4.28-pre-4 (includes minor fixes).
Add --noheadings columns option for colon-separated dmsetup output. Add --noheadings columns option for colon-separated dmsetup output.
Support device referencing by uuid or major/minor. Support device referencing by uuid or major/minor.

View File

@ -24,6 +24,9 @@ INCLUDES = -I$(interface)
LIB_STATIC = $(interface)/libdevmapper.a LIB_STATIC = $(interface)/libdevmapper.a
LIB_SHARED = $(interface)/libdevmapper.so LIB_SHARED = $(interface)/libdevmapper.so
CFLAGS += -DDEVICE_UID=@DEVICE_UID@ -DDEVICE_GID=@DEVICE_GID@ \
-DDEVICE_MODE=@DEVICE_MODE@
include ../make.tmpl include ../make.tmpl
.PHONY: install_dynamic install_static \ .PHONY: install_dynamic install_static \

View File

@ -501,7 +501,8 @@ static int _dm_task_run_v1(struct dm_task *dmt)
switch (dmt->type) { switch (dmt->type) {
case DM_DEVICE_CREATE: case DM_DEVICE_CREATE:
add_dev_node(dmt->dev_name, MAJOR(dmi->dev), MINOR(dmi->dev)); add_dev_node(dmt->dev_name, MAJOR(dmi->dev), MINOR(dmi->dev),
dmt->uid, dmt->gid, dmt->mode);
break; break;
case DM_DEVICE_REMOVE: case DM_DEVICE_REMOVE:
@ -515,7 +516,8 @@ static int _dm_task_run_v1(struct dm_task *dmt)
case DM_DEVICE_MKNODES: case DM_DEVICE_MKNODES:
if (dmi->flags & DM_EXISTS_FLAG) if (dmi->flags & DM_EXISTS_FLAG)
add_dev_node(dmt->dev_name, MAJOR(dmi->dev), add_dev_node(dmt->dev_name, MAJOR(dmi->dev),
MINOR(dmi->dev)); MINOR(dmi->dev),
dmt->uid, dmt->gid, dmt->mode);
else else
rm_dev_node(dmt->dev_name); rm_dev_node(dmt->dev_name);
break; break;
@ -1194,7 +1196,8 @@ int dm_task_run(struct dm_task *dmt)
ignore_error: ignore_error:
switch (dmt->type) { switch (dmt->type) {
case DM_DEVICE_CREATE: case DM_DEVICE_CREATE:
add_dev_node(dmt->dev_name, MAJOR(dmi->dev), MINOR(dmi->dev)); add_dev_node(dmt->dev_name, MAJOR(dmi->dev), MINOR(dmi->dev),
dmt->uid, dmt->gid, dmt->mode);
break; break;
case DM_DEVICE_REMOVE: case DM_DEVICE_REMOVE:
@ -1212,7 +1215,8 @@ int dm_task_run(struct dm_task *dmt)
case DM_DEVICE_MKNODES: case DM_DEVICE_MKNODES:
if (dmi->flags & DM_EXISTS_FLAG) if (dmi->flags & DM_EXISTS_FLAG)
add_dev_node(dmi->name, MAJOR(dmi->dev), add_dev_node(dmi->name, MAJOR(dmi->dev),
MINOR(dmi->dev)); MINOR(dmi->dev),
dmt->uid, dmt->gid, dmt->mode);
else if (dmt->dev_name) else if (dmt->dev_name)
rm_dev_node(dmt->dev_name); rm_dev_node(dmt->dev_name);
break; break;

View File

@ -17,6 +17,7 @@
#define LIB_DMTARGETS_H #define LIB_DMTARGETS_H
#include <inttypes.h> #include <inttypes.h>
#include <sys/types.h>
struct dm_ioctl; struct dm_ioctl;
struct dm_ioctl_v1; struct dm_ioctl_v1;
@ -40,6 +41,9 @@ struct dm_task {
uint32_t event_nr; uint32_t event_nr;
int major; int major;
int minor; int minor;
uid_t uid;
gid_t gid;
mode_t mode;
union { union {
struct dm_ioctl *v4; struct dm_ioctl *v4;
struct dm_ioctl_v1 *v1; struct dm_ioctl_v1 *v1;

View File

@ -113,6 +113,9 @@ struct dm_task *dm_task_create(int type)
dmt->type = type; dmt->type = type;
dmt->minor = -1; dmt->minor = -1;
dmt->major = -1; dmt->major = -1;
dmt->uid = DEVICE_UID;
dmt->gid = DEVICE_GID;
dmt->mode = DEVICE_MODE;
return dmt; return dmt;
} }
@ -226,11 +229,13 @@ static int _set_selinux_context(const char *path)
} }
#endif #endif
static int _add_dev_node(const char *dev_name, uint32_t major, uint32_t minor) static int _add_dev_node(const char *dev_name, uint32_t major, uint32_t minor,
uid_t uid, gid_t gid, mode_t mode)
{ {
char path[PATH_MAX]; char path[PATH_MAX];
struct stat info; struct stat info;
dev_t dev = MKDEV(major, minor); dev_t dev = MKDEV(major, minor);
mode_t old_mask;
_build_dev_path(path, sizeof(path), dev_name); _build_dev_path(path, sizeof(path), dev_name);
@ -241,6 +246,7 @@ static int _add_dev_node(const char *dev_name, uint32_t major, uint32_t minor)
return 0; return 0;
} }
/* If right inode already exists we don't touch uid etc. */
if (info.st_rdev == dev) if (info.st_rdev == dev)
return 1; return 1;
@ -251,10 +257,18 @@ static int _add_dev_node(const char *dev_name, uint32_t major, uint32_t minor)
} }
} }
if (mknod(path, S_IFBLK | S_IRUSR | S_IWUSR | S_IRGRP, dev) < 0) { old_mask = umask(0);
if (mknod(path, S_IFBLK | mode, dev) < 0) {
log_error("Unable to make device node for '%s'", dev_name); log_error("Unable to make device node for '%s'", dev_name);
return 0; return 0;
} }
umask(old_mask);
if (chown(path, uid, gid) < 0) {
log_error("%s: chown failed: %s", path, strerror(errno));
return 0;
}
#ifdef HAVE_SELINUX #ifdef HAVE_SELINUX
if (!_set_selinux_context(path)) if (!_set_selinux_context(path))
return 0; return 0;
@ -324,11 +338,12 @@ typedef enum {
} node_op_t; } node_op_t;
static int _do_node_op(node_op_t type, const char *dev_name, uint32_t major, static int _do_node_op(node_op_t type, const char *dev_name, uint32_t major,
uint32_t minor, const char *old_name) uint32_t minor, uid_t uid, gid_t gid, mode_t mode,
const char *old_name)
{ {
switch (type) { switch (type) {
case NODE_ADD: case NODE_ADD:
return _add_dev_node(dev_name, major, minor); return _add_dev_node(dev_name, major, minor, uid, gid, mode);
case NODE_DEL: case NODE_DEL:
return _rm_dev_node(dev_name); return _rm_dev_node(dev_name);
case NODE_RENAME: case NODE_RENAME:
@ -346,6 +361,9 @@ struct node_op_parms {
char *dev_name; char *dev_name;
uint32_t major; uint32_t major;
uint32_t minor; uint32_t minor;
uid_t uid;
gid_t gid;
mode_t mode;
char *old_name; char *old_name;
char names[0]; char names[0];
}; };
@ -358,7 +376,8 @@ static void _store_str(char **pos, char **ptr, const char *str)
} }
static int _stack_node_op(node_op_t type, const char *dev_name, uint32_t major, static int _stack_node_op(node_op_t type, const char *dev_name, uint32_t major,
uint32_t minor, const char *old_name) uint32_t minor, uid_t uid, gid_t gid, mode_t mode,
const char *old_name)
{ {
struct node_op_parms *nop; struct node_op_parms *nop;
size_t len = strlen(dev_name) + strlen(old_name) + 2; size_t len = strlen(dev_name) + strlen(old_name) + 2;
@ -373,6 +392,9 @@ static int _stack_node_op(node_op_t type, const char *dev_name, uint32_t major,
nop->type = type; nop->type = type;
nop->major = major; nop->major = major;
nop->minor = minor; nop->minor = minor;
nop->uid = uid;
nop->gid = gid;
nop->mode = mode;
_store_str(&pos, &nop->dev_name, dev_name); _store_str(&pos, &nop->dev_name, dev_name);
_store_str(&pos, &nop->old_name, old_name); _store_str(&pos, &nop->old_name, old_name);
@ -390,25 +412,27 @@ static void _pop_node_ops(void)
list_iterate_safe(noph, nopht, &_node_ops) { list_iterate_safe(noph, nopht, &_node_ops) {
nop = list_item(noph, struct node_op_parms); nop = list_item(noph, struct node_op_parms);
_do_node_op(nop->type, nop->dev_name, nop->major, nop->minor, _do_node_op(nop->type, nop->dev_name, nop->major, nop->minor,
nop->old_name); nop->uid, nop->gid, nop->mode, nop->old_name);
list_del(&nop->list); list_del(&nop->list);
free(nop); free(nop);
} }
} }
int add_dev_node(const char *dev_name, uint32_t major, uint32_t minor) int add_dev_node(const char *dev_name, uint32_t major, uint32_t minor,
uid_t uid, gid_t gid, mode_t mode)
{ {
return _stack_node_op(NODE_ADD, dev_name, major, minor, ""); return _stack_node_op(NODE_ADD, dev_name, major, minor, uid, gid, mode,
"");
} }
int rename_dev_node(const char *old_name, const char *new_name) int rename_dev_node(const char *old_name, const char *new_name)
{ {
return _stack_node_op(NODE_RENAME, new_name, 0, 0, old_name); return _stack_node_op(NODE_RENAME, new_name, 0, 0, 0, 0, 0, old_name);
} }
int rm_dev_node(const char *dev_name) int rm_dev_node(const char *dev_name)
{ {
return _stack_node_op(NODE_DEL, dev_name, 0, 0, ""); return _stack_node_op(NODE_DEL, dev_name, 0, 0, 0, 0, 0, "");
} }
void update_devs(void) void update_devs(void)

View File

@ -22,7 +22,8 @@ struct target *create_target(uint64_t start,
uint64_t len, uint64_t len,
const char *type, const char *params); const char *type, const char *params);
int add_dev_node(const char *dev_name, uint32_t minor, uint32_t major); int add_dev_node(const char *dev_name, uint32_t minor, uint32_t major,
uid_t uid, gid_t gid, mode_t mode);
int rm_dev_node(const char *dev_name); int rm_dev_node(const char *dev_name);
int rename_dev_node(const char *old_name, const char *new_name); int rename_dev_node(const char *old_name, const char *new_name);
void update_devs(void); void update_devs(void);