bluray.c 3.06 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 10 11 12 13
#if HAVE_BDPLUS
#include "libbdplus/bdplus.h"
#endif


cRTrn13's avatar
cRTrn13 committed
14 15 16 17 18
BLURAY *bd_open(const char* device_path, const char* keyfile_path)
{
    BLURAY *bd = malloc(sizeof(BLURAY));

    bd->aacs = NULL;
cRTrn13's avatar
cRTrn13 committed
19
    bd->h_libaacs = NULL;
cRTrn13's avatar
cRTrn13 committed
20
    bd->fp = NULL;
cRTrn13's avatar
cRTrn13 committed
21
    strncpy(bd->device_path, device_path, 100);
cRTrn13's avatar
cRTrn13 committed
22 23

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

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

29
        fptr fptr_s = dlsym(bd->h_libaacs, "aacs_open");
cRTrn13's avatar
cRTrn13 committed
30
        bd->aacs = fptr_s(device_path, keyfile_path);
cRTrn13's avatar
cRTrn13 committed
31 32
    } else {
        DEBUG(DBG_BLURAY, "libaacs not present\n");
cRTrn13's avatar
cRTrn13 committed
33 34
    }

cRTrn13's avatar
cRTrn13 committed
35 36
    DEBUG(DBG_BLURAY, "BLURAY initialized! (0x%08x)\n", bd);

cRTrn13's avatar
cRTrn13 committed
37 38 39 40 41
    return bd;
}

void bd_close(BLURAY *bd)
{
42
    if (bd->h_libaacs) {
cRTrn13's avatar
cRTrn13 committed
43 44
        typedef void* (*fptr)();

45
        fptr fptr_s = dlsym(bd->h_libaacs, "aacs_close");
cRTrn13's avatar
cRTrn13 committed
46
        fptr_s(bd->aacs);
cRTrn13's avatar
cRTrn13 committed
47 48
    }

49
    dlclose(bd->h_libaacs);
cRTrn13's avatar
cRTrn13 committed
50

cRTrn13's avatar
cRTrn13 committed
51 52 53
    if (bd->fp) {
        file_close(bd->fp);
    }
cRTrn13's avatar
cRTrn13 committed
54 55

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

    X_FREE(bd);
cRTrn13's avatar
cRTrn13 committed
58
}
cRTrn13's avatar
cRTrn13 committed
59

cRTrn13's avatar
cRTrn13 committed
60
off_t bd_seek(BLURAY *bd, uint64_t pos)
cRTrn13's avatar
cRTrn13 committed
61 62 63 64
{
    if (pos < bd->s_size) {
        bd->s_pos = pos - (pos % 6144);

cRTrn13's avatar
cRTrn13 committed
65
        file_seek(bd->fp, bd->s_pos, SEEK_SET);
66 67

        DEBUG(DBG_BLURAY, "Seek to %ld (0x%08x)\n", bd->s_pos, bd);
cRTrn13's avatar
cRTrn13 committed
68 69 70 71 72 73 74
    }

    return bd->s_pos;
}

int bd_read(BLURAY *bd, unsigned char *buf, int len)
{
75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
    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
90 91
                }

92
                bd->s_pos += len;
cRTrn13's avatar
cRTrn13 committed
93

94 95 96 97
                DEBUG(DBG_BLURAY, "%d bytes read OK! (0x%08x)\n", read_len, bd);

                return read_len;
            }
cRTrn13's avatar
cRTrn13 committed
98 99 100
        }
    }

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

cRTrn13's avatar
cRTrn13 committed
103 104
    return 0;
}
cRTrn13's avatar
cRTrn13 committed
105 106 107 108 109 110 111 112 113 114 115 116 117 118

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))) {
119 120 121
            bd_seek(bd, 0);

            DEBUG(DBG_BLURAY, "Title %s selected! (0x%08x)\n", f_name, bd);
cRTrn13's avatar
cRTrn13 committed
122 123 124

            return 1;
        }
125 126

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

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

cRTrn13's avatar
cRTrn13 committed
131 132
    return 0;
}