Skip to content
Snippets Groups Projects
Select Git revision
  • af43cd033c64384c521a9cb1fb68660d7799435c
  • master default protected
  • android-7.1.2_r28_klist
  • oreo-mr1-iot-release
  • sdk-release
  • pie-cts-dev
  • pie-cts-release
  • pie-vts-release
  • nougat-iot-release
  • pie-gsi
  • pie-platform-release
  • pie-r2-release
  • pie-r2-s1-release
  • pie-release
  • pie-dev
  • oreo-m4-s4-release
  • o-mr1-iot-preview-8
  • oreo-m2-s2-release
  • oreo-m2-s1-release
  • oreo-m6-s2-release
  • oreo-m6-s3-release
  • android-o-mr1-iot-release-1.0.4
  • android-9.0.0_r8
  • android-9.0.0_r7
  • android-9.0.0_r6
  • android-9.0.0_r5
  • android-8.1.0_r46
  • android-8.1.0_r45
  • android-n-iot-release-smart-display-r2
  • android-vts-8.1_r5
  • android-cts-8.1_r8
  • android-cts-8.0_r12
  • android-cts-7.1_r20
  • android-cts-7.0_r24
  • android-cts-6.0_r31
  • android-o-mr1-iot-release-1.0.3
  • android-cts-9.0_r1
  • android-8.1.0_r43
  • android-8.1.0_r42
  • android-n-iot-release-smart-display
  • android-p-preview-5
41 results

r.c

Blame
  • load_policy.c 1.11 KiB
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <unistd.h>
    #include <fcntl.h>
    #include <sys/stat.h>
    #include <sys/mman.h>
    #include <errno.h>
    #include <selinux/selinux.h>
    
    int load_policy_main(int argc, char **argv)
    {
        int fd, rc;
        struct stat sb;
        void *map;
        const char *path;
    
        if (argc != 2) {
            fprintf(stderr, "usage:  %s policy-file\n", argv[0]);
            exit(1);
        }
    
        path = argv[1];
        fd = open(path, O_RDONLY);
        if (fd < 0) {
            fprintf(stderr, "Could not open %s:  %s\n", path, strerror(errno));
            exit(2);
        }
    
        if (fstat(fd, &sb) < 0) {
            fprintf(stderr, "Could not stat %s:  %s\n", path, strerror(errno));
            exit(3);
        }
    
        map = mmap(NULL, sb.st_size, PROT_READ, MAP_PRIVATE, fd, 0);
        if (map == MAP_FAILED) {
            fprintf(stderr, "Could not mmap %s:  %s\n", path, strerror(errno));
            exit(4);
        }
    
        rc = security_load_policy(map, sb.st_size);
        if (rc < 0) {
            fprintf(stderr, "Could not load %s:  %s\n", path, strerror(errno));
            exit(5);
        }
        munmap(map, sb.st_size);
        close(fd);
        exit(0);
    }