SELinux: load_policy applet - this time with svn add
This commit is contained in:
parent
1fc6e56684
commit
644849a3aa
31
selinux/load_policy.c
Normal file
31
selinux/load_policy.c
Normal file
@ -0,0 +1,31 @@
|
||||
/*
|
||||
* load_policy
|
||||
* This implementation is based on old load_policy to be small.
|
||||
* Author: Yuichi Nakamura <ynakam@hitachisoft.jp>
|
||||
*/
|
||||
#include "busybox.h"
|
||||
|
||||
int load_policy_main(int argc, char *argv[]);
|
||||
int load_policy_main(int argc, char *argv[])
|
||||
{
|
||||
int fd;
|
||||
struct stat st;
|
||||
void *data;
|
||||
if (argc != 2) {
|
||||
bb_show_usage();
|
||||
}
|
||||
|
||||
fd = xopen(argv[1], O_RDONLY);
|
||||
if (fstat(fd, &st) < 0) {
|
||||
bb_perror_msg_and_die("can't fstat");
|
||||
}
|
||||
data = mmap(NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0);
|
||||
if (data == MAP_FAILED) {
|
||||
bb_perror_msg_and_die("can't mmap");
|
||||
}
|
||||
if (security_load_policy(data, st.st_size) < 0) {
|
||||
bb_perror_msg_and_die("can't load policy");
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue
Block a user