mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-01-13 20:13:38 +00:00
Adjustments for unified binary
This commit is contained in:
parent
dc9670c439
commit
cd498711bc
@ -3,9 +3,9 @@ LOCAL_PATH := $(call my-dir)
|
|||||||
include $(CLEAR_VARS)
|
include $(CLEAR_VARS)
|
||||||
LOCAL_MODULE := magiskpolicy
|
LOCAL_MODULE := magiskpolicy
|
||||||
LOCAL_STATIC_LIBRARIES := libsepol
|
LOCAL_STATIC_LIBRARIES := libsepol
|
||||||
LOCAL_SRC_FILES := main.c sepolicy.c rules.c utils.c
|
LOCAL_SRC_FILES := magiskpolicy.c sepolicy.c rules.c utils.c ../utils/vector.c
|
||||||
LOCAL_C_INCLUDES := jni/selinux/libsepol/include/
|
LOCAL_C_INCLUDES := jni/selinux/libsepol/include jni/utils
|
||||||
LOCAL_CFLAGS += -std=gnu11
|
LOCAL_CFLAGS := -DINDEP_BINARY
|
||||||
include $(BUILD_EXECUTABLE)
|
include $(BUILD_EXECUTABLE)
|
||||||
|
|
||||||
include jni/selinux/libsepol/Android.mk
|
include jni/selinux/libsepol/Android.mk
|
||||||
|
@ -1,5 +1,15 @@
|
|||||||
|
#include "vector.h"
|
||||||
#include "magiskpolicy.h"
|
#include "magiskpolicy.h"
|
||||||
|
|
||||||
|
#ifdef INDEP_BINARY
|
||||||
|
int magiskpolicy_main(int argc, char *argv[]);
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
return magiskpolicy_main(argc, argv);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#include "magisk.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
static int syntax_err = 0;
|
static int syntax_err = 0;
|
||||||
static char err_msg[ARG_MAX];
|
static char err_msg[ARG_MAX];
|
||||||
|
|
||||||
@ -52,7 +62,7 @@ static void usage(char *arg0) {
|
|||||||
static int parse_pattern_1(int action, char* statement) {
|
static int parse_pattern_1(int action, char* statement) {
|
||||||
int state = 0, in_bracket = 0;
|
int state = 0, in_bracket = 0;
|
||||||
char *tok, *class, *saveptr;
|
char *tok, *class, *saveptr;
|
||||||
vector source, target, permission, *temp;
|
struct vector source, target, permission, *temp;
|
||||||
vec_init(&source);
|
vec_init(&source);
|
||||||
vec_init(&target);
|
vec_init(&target);
|
||||||
vec_init(&permission);
|
vec_init(&permission);
|
||||||
@ -130,7 +140,7 @@ static int parse_pattern_1(int action, char* statement) {
|
|||||||
static int parse_pattern_2(int action, char* statement) {
|
static int parse_pattern_2(int action, char* statement) {
|
||||||
int state = 0, in_bracket = 0;
|
int state = 0, in_bracket = 0;
|
||||||
char *tok, *saveptr;
|
char *tok, *saveptr;
|
||||||
vector class, attribute, *temp;
|
struct vector class, attribute, *temp;
|
||||||
vec_init(&class);
|
vec_init(&class);
|
||||||
vec_init(&attribute);
|
vec_init(&attribute);
|
||||||
tok = strtok_r(statement, " ", &saveptr);
|
tok = strtok_r(statement, " ", &saveptr);
|
||||||
@ -185,7 +195,7 @@ static int parse_pattern_2(int action, char* statement) {
|
|||||||
// Pattern 3: action { type }
|
// Pattern 3: action { type }
|
||||||
static int parse_pattern_3(int action, char* statement) {
|
static int parse_pattern_3(int action, char* statement) {
|
||||||
char *tok, *saveptr;
|
char *tok, *saveptr;
|
||||||
vector classes;
|
struct vector classes;
|
||||||
vec_init(&classes);
|
vec_init(&classes);
|
||||||
tok = strtok_r(statement, " {}", &saveptr);
|
tok = strtok_r(statement, " {}", &saveptr);
|
||||||
while (tok != NULL) {
|
while (tok != NULL) {
|
||||||
@ -253,7 +263,7 @@ static void syntax_error_msg() {
|
|||||||
syntax_err = 1;
|
syntax_err = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int magiskpolicy_main(int argc, char *argv[]) {
|
||||||
char *infile = NULL, *outfile = NULL, *tok, *saveptr;
|
char *infile = NULL, *outfile = NULL, *tok, *saveptr;
|
||||||
int live = 0, minimal = 0, full = 0;
|
int live = 0, minimal = 0, full = 0;
|
||||||
struct vector rules;
|
struct vector rules;
|
@ -22,6 +22,8 @@
|
|||||||
#include <sepol/policydb/conditional.h>
|
#include <sepol/policydb/conditional.h>
|
||||||
#include <sepol/policydb/constraint.h>
|
#include <sepol/policydb/constraint.h>
|
||||||
|
|
||||||
|
#include "vector.h"
|
||||||
|
|
||||||
// hashtab traversal macro
|
// hashtab traversal macro
|
||||||
#define hashtab_for_each(table, ptr) \
|
#define hashtab_for_each(table, ptr) \
|
||||||
for (int _i = 0; _i < table->size; ++_i) \
|
for (int _i = 0; _i < table->size; ++_i) \
|
||||||
@ -52,16 +54,6 @@ int enforce(char *s);
|
|||||||
int attradd(char *s, char *a);
|
int attradd(char *s, char *a);
|
||||||
int exists(char *source);
|
int exists(char *source);
|
||||||
|
|
||||||
// Vector of char*
|
|
||||||
typedef struct vector {
|
|
||||||
size_t size;
|
|
||||||
size_t cap;
|
|
||||||
char **data;
|
|
||||||
} vector;
|
|
||||||
void vec_init(vector *v);
|
|
||||||
void vec_push_back(vector *v, char* s);
|
|
||||||
void vec_destroy(vector *v);
|
|
||||||
|
|
||||||
// Built in rules
|
// Built in rules
|
||||||
void full_rules();
|
void full_rules();
|
||||||
void min_rules();
|
void min_rules();
|
||||||
|
22
utils.c
22
utils.c
@ -1,27 +1,5 @@
|
|||||||
#include "magiskpolicy.h"
|
#include "magiskpolicy.h"
|
||||||
|
|
||||||
void vec_init(vector *v) {
|
|
||||||
v->size = 0;
|
|
||||||
v->cap = 1;
|
|
||||||
v->data = (char**) malloc(sizeof(char*));
|
|
||||||
}
|
|
||||||
|
|
||||||
void vec_push_back(vector *v, char* s) {
|
|
||||||
if (v == NULL) return;
|
|
||||||
if (v->size == v->cap) {
|
|
||||||
v->cap *= 2;
|
|
||||||
v->data = (char**) realloc(v->data, sizeof(char*) * v->cap);
|
|
||||||
}
|
|
||||||
v->data[v->size] = s;
|
|
||||||
++v->size;
|
|
||||||
}
|
|
||||||
|
|
||||||
void vec_destroy(vector *v) {
|
|
||||||
v->size = 0;
|
|
||||||
v->cap = 0;
|
|
||||||
free(v->data);
|
|
||||||
}
|
|
||||||
|
|
||||||
int allow(char *s, char *t, char *c, char *p) {
|
int allow(char *s, char *t, char *c, char *p) {
|
||||||
return add_rule(s, t, c, p, AVTAB_ALLOWED, 0);
|
return add_rule(s, t, c, p, AVTAB_ALLOWED, 0);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user