bluray.c 3.33 KB
Newer Older
cRTrn13's avatar
cRTrn13 committed
1

cRTrn13's avatar
cRTrn13 committed
2
#include <dlfcn.h>
cRTrn13's avatar
cRTrn13 committed
3
#include <stdio.h>
cRTrn13's avatar
cRTrn13 committed
4

cRTrn13's avatar
cRTrn13 committed
5
#include "bluray.h"
cRTrn13's avatar
cRTrn13 committed
6
#include "util/macro.h"
cRTrn13's avatar
cRTrn13 committed
7
#include "util/logging.h"
cRTrn13's avatar
cRTrn13 committed
8

Accident's avatar
 
Accident committed
9

cRTrn13's avatar
cRTrn13 committed
10 11
BLURAY *bd_open(const char* device_path, const char* keyfile_path)
{
cRTrn13's avatar
cRTrn13 committed
12
    BLURAY *bd = NULL;
cRTrn13's avatar
cRTrn13 committed
13 14

    bd->aacs = NULL;
cRTrn13's avatar
cRTrn13 committed
15
    bd->h_libaacs = NULL;
cRTrn13's avatar
cRTrn13 committed
16
    bd->fp = NULL;
cRTrn13's avatar
cRTrn13 committed
17

cRTrn13's avatar
cRTrn13 committed
18 19 20 21 22 23 24 25
    if (device_path) {
        strncpy(bd->device_path, device_path, 100);

        bd = malloc(sizeof(BLURAY));

        if (keyfile_path) {
            if ((bd->h_libaacs = dlopen("libaacs.so", RTLD_LAZY))) {
                DEBUG(DBG_BLURAY, "Downloaded libaacs (0x%08x)\n", bd->h_libaacs);
cRTrn13's avatar
cRTrn13 committed
26

cRTrn13's avatar
cRTrn13 committed
27
                typedef AACS_KEYS* (*fptr)();
cRTrn13's avatar
cRTrn13 committed
28

cRTrn13's avatar
cRTrn13 committed
29 30 31 32 33 34 35 36 37 38
                fptr fptr_s = dlsym(bd->h_libaacs, "aacs_open");
                bd->aacs = fptr_s(device_path, keyfile_path);
            } else {
                DEBUG(DBG_BLURAY, "libaacs not present\n");
            }
        } else {
            DEBUG(DBG_BLURAY, "No keyfile provided. You will not be able to make use of crypto functionality (0x%08x)\n", bd);
        }

        DEBUG(DBG_BLURAY, "BLURAY initialized! (0x%08x)\n", bd);
cRTrn13's avatar
cRTrn13 committed
39
    } else {
cRTrn13's avatar
cRTrn13 committed
40
        DEBUG(DBG_BLURAY, "No device path provided!\n");
cRTrn13's avatar
cRTrn13 committed
41 42 43 44 45 46 47
    }

    return bd;
}

void bd_close(BLURAY *bd)
{
48
    if (bd->h_libaacs) {
cRTrn13's avatar
cRTrn13 committed
49 50
        typedef void* (*fptr)();

51
        fptr fptr_s = dlsym(bd->h_libaacs, "aacs_close");
cRTrn13's avatar
cRTrn13 committed
52
        fptr_s(bd->aacs);
cRTrn13's avatar
cRTrn13 committed
53 54
    }

55
    dlclose(bd->h_libaacs);
cRTrn13's avatar
cRTrn13 committed
56

cRTrn13's avatar
cRTrn13 committed
57 58 59
    if (bd->fp) {
        file_close(bd->fp);
    }
cRTrn13's avatar
cRTrn13 committed
60 61

    DEBUG(DBG_BLURAY, "BLURAY destroyed! (0x%08x)\n", bd);
cRTrn13's avatar
cRTrn13 committed
62 63

    X_FREE(bd);
cRTrn13's avatar
cRTrn13 committed
64
}
cRTrn13's avatar
cRTrn13 committed
65

cRTrn13's avatar
cRTrn13 committed
66
off_t bd_seek(BLURAY *bd, uint64_t pos)
cRTrn13's avatar
cRTrn13 committed
67 68 69 70
{
    if (pos < bd->s_size) {
        bd->s_pos = pos - (pos % 6144);

cRTrn13's avatar
cRTrn13 committed
71
        file_seek(bd->fp, bd->s_pos, SEEK_SET);
72 73

        DEBUG(DBG_BLURAY, "Seek to %ld (0x%08x)\n", bd->s_pos, bd);
cRTrn13's avatar
cRTrn13 committed
74 75 76 77 78 79 80
    }

    return bd->s_pos;
}

int bd_read(BLURAY *bd, unsigned char *buf, int len)
{
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
    if (bd->fp) {
        DEBUG(DBG_BLURAY, "Reading unit [%d bytes] at %ld... (0x%08x)\n", len, bd->s_pos, bd);

        if (len + bd->s_pos < bd->s_size) {
            int read_len;

            if ((read_len = file_read(bd->fp, buf, len))) {
                if (bd->h_libaacs) {
                    if ((bd->libaacs_decrypt_unit = dlsym(bd->h_libaacs, "aacs_decrypt_unit"))) {
                        if (!bd->libaacs_decrypt_unit(bd->aacs, buf, len, bd->s_pos)) {
                            DEBUG(DBG_BLURAY, "Unable decrypt unit! (0x%08x)\n", bd);

                            return 0;
                        }
                    }
cRTrn13's avatar
cRTrn13 committed
96 97
                }

98
                bd->s_pos += len;
cRTrn13's avatar
cRTrn13 committed
99

100 101 102 103
                DEBUG(DBG_BLURAY, "%d bytes read OK! (0x%08x)\n", read_len, bd);

                return read_len;
            }
cRTrn13's avatar
cRTrn13 committed
104 105 106
        }
    }

107 108
    DEBUG(DBG_BLURAY, "No valid title selected! (0x%08x)\n", bd->s_pos);

cRTrn13's avatar
cRTrn13 committed
109 110
    return 0;
}
cRTrn13's avatar
cRTrn13 committed
111 112 113 114 115 116 117 118 119 120 121 122 123 124

int bd_select_title(BLURAY *bd, uint64_t title)
{
    char f_name[100];

    memset(f_name, 0, sizeof(f_name));
    snprintf(f_name, 100, "%s/BDMV/STREAM/%05ld.m2ts", bd->device_path, title);

    bd->s_size = 0;
    bd->s_pos = 0;

    if ((bd->fp = file_open(f_name, "rb"))) {
        file_seek(bd->fp, 0, SEEK_END);
        if ((bd->s_size = file_tell(bd->fp))) {
125 126 127
            bd_seek(bd, 0);

            DEBUG(DBG_BLURAY, "Title %s selected! (0x%08x)\n", f_name, bd);
cRTrn13's avatar
cRTrn13 committed
128 129 130

            return 1;
        }
131 132

        DEBUG(DBG_BLURAY, "Title %s empty! (0x%08x)\n", f_name, bd);
cRTrn13's avatar
cRTrn13 committed
133 134
    }

135 136
    DEBUG(DBG_BLURAY, "Unable to select title %s! (0x%08x)\n", f_name, bd);

cRTrn13's avatar
cRTrn13 committed
137 138
    return 0;
}