my first commit, i only added the file TEST to see how it works
[cinelerra_cv/mob.git] / libmpeg3 / mpeg3css.c
blobb770ab33d0b0a33d501afef44cf098c44593ce40
1 /*
2 * Copyright (C) 2000 Derek Fawcus et. al. <derek@spider.com>
3 * Ported to libmpeg3 by et. al.
5 * This code may be used under the terms of Version 2 of the GPL,
6 * read the file COPYING for details.
8 */
11 * These routines do some reordering of the supplied data before
12 * calling engine() to do the main work.
14 * The reordering seems similar to that done by the initial stages of
15 * the DES algorithm, in that it looks like it's just been done to
16 * try and make software decoding slower. I'm not sure that it
17 * actually adds anything to the security.
19 * The nature of the shuffling is that the bits of the supplied
20 * parameter 'varient' are reorganised (and some inverted), and
21 * the bytes of the parameter 'challenge' are reorganised.
23 * The reorganisation in each routine is different, and the first
24 * (CryptKey1) does not bother of play with the 'varient' parameter.
26 * Since this code is only run once per disk change, I've made the
27 * code table driven in order to improve readability.
29 * Since these routines are so similar to each other, one could even
30 * abstract them all to one routine supplied a parameter determining
31 * the nature of the reordering it has to do.
35 #ifdef HAVE_CSS
37 #include "mpeg3css.h"
38 #include "mpeg3private.h"
41 #include <unistd.h>
42 #include <fcntl.h>
43 // Must unlink /usr/include directories from the kernel source for this to work.
44 #include <linux/cdrom.h>
45 #include <stdlib.h>
46 #include <string.h>
47 #include <sys/ioctl.h>
48 #include <sys/stat.h>
49 #include <sys/types.h>
52 #ifndef FIBMAP
53 #define FIBMAP _IO(0x00,1) /* bmap access */
54 //#define FIBMAP 1
55 #endif
57 /* =================================== TABLES ================================ */
59 static unsigned char mpeg3css_varients[] =
61 0xB7, 0x74, 0x85, 0xD0, 0xCC, 0xDB, 0xCA, 0x73,
62 0x03, 0xFE, 0x31, 0x03, 0x52, 0xE0, 0xB7, 0x42,
63 0x63, 0x16, 0xF2, 0x2A, 0x79, 0x52, 0xFF, 0x1B,
64 0x7A, 0x11, 0xCA, 0x1A, 0x9B, 0x40, 0xAD, 0x01
67 static unsigned char mpeg3css_secret[] = {0x55, 0xD6, 0xC4, 0xC5, 0x28};
69 static unsigned char mpeg3css_table0[] =
71 0xB7, 0xF4, 0x82, 0x57, 0xDA, 0x4D, 0xDB, 0xE2,
72 0x2F, 0x52, 0x1A, 0xA8, 0x68, 0x5A, 0x8A, 0xFF,
73 0xFB, 0x0E, 0x6D, 0x35, 0xF7, 0x5C, 0x76, 0x12,
74 0xCE, 0x25, 0x79, 0x29, 0x39, 0x62, 0x08, 0x24,
75 0xA5, 0x85, 0x7B, 0x56, 0x01, 0x23, 0x68, 0xCF,
76 0x0A, 0xE2, 0x5A, 0xED, 0x3D, 0x59, 0xB0, 0xA9,
77 0xB0, 0x2C, 0xF2, 0xB8, 0xEF, 0x32, 0xA9, 0x40,
78 0x80, 0x71, 0xAF, 0x1E, 0xDE, 0x8F, 0x58, 0x88,
79 0xB8, 0x3A, 0xD0, 0xFC, 0xC4, 0x1E, 0xB5, 0xA0,
80 0xBB, 0x3B, 0x0F, 0x01, 0x7E, 0x1F, 0x9F, 0xD9,
81 0xAA, 0xB8, 0x3D, 0x9D, 0x74, 0x1E, 0x25, 0xDB,
82 0x37, 0x56, 0x8F, 0x16, 0xBA, 0x49, 0x2B, 0xAC,
83 0xD0, 0xBD, 0x95, 0x20, 0xBE, 0x7A, 0x28, 0xD0,
84 0x51, 0x64, 0x63, 0x1C, 0x7F, 0x66, 0x10, 0xBB,
85 0xC4, 0x56, 0x1A, 0x04, 0x6E, 0x0A, 0xEC, 0x9C,
86 0xD6, 0xE8, 0x9A, 0x7A, 0xCF, 0x8C, 0xDB, 0xB1,
87 0xEF, 0x71, 0xDE, 0x31, 0xFF, 0x54, 0x3E, 0x5E,
88 0x07, 0x69, 0x96, 0xB0, 0xCF, 0xDD, 0x9E, 0x47,
89 0xC7, 0x96, 0x8F, 0xE4, 0x2B, 0x59, 0xC6, 0xEE,
90 0xB9, 0x86, 0x9A, 0x64, 0x84, 0x72, 0xE2, 0x5B,
91 0xA2, 0x96, 0x58, 0x99, 0x50, 0x03, 0xF5, 0x38,
92 0x4D, 0x02, 0x7D, 0xE7, 0x7D, 0x75, 0xA7, 0xB8,
93 0x67, 0x87, 0x84, 0x3F, 0x1D, 0x11, 0xE5, 0xFC,
94 0x1E, 0xD3, 0x83, 0x16, 0xA5, 0x29, 0xF6, 0xC7,
95 0x15, 0x61, 0x29, 0x1A, 0x43, 0x4F, 0x9B, 0xAF,
96 0xC5, 0x87, 0x34, 0x6C, 0x0F, 0x3B, 0xA8, 0x1D,
97 0x45, 0x58, 0x25, 0xDC, 0xA8, 0xA3, 0x3B, 0xD1,
98 0x79, 0x1B, 0x48, 0xF2, 0xE9, 0x93, 0x1F, 0xFC,
99 0xDB, 0x2A, 0x90, 0xA9, 0x8A, 0x3D, 0x39, 0x18,
100 0xA3, 0x8E, 0x58, 0x6C, 0xE0, 0x12, 0xBB, 0x25,
101 0xCD, 0x71, 0x22, 0xA2, 0x64, 0xC6, 0xE7, 0xFB,
102 0xAD, 0x94, 0x77, 0x04, 0x9A, 0x39, 0xCF, 0x7C
105 static unsigned char mpeg3css_table1[] =
107 0x8C, 0x47, 0xB0, 0xE1, 0xEB, 0xFC, 0xEB, 0x56,
108 0x10, 0xE5, 0x2C, 0x1A, 0x5D, 0xEF, 0xBE, 0x4F,
109 0x08, 0x75, 0x97, 0x4B, 0x0E, 0x25, 0x8E, 0x6E,
110 0x39, 0x5A, 0x87, 0x53, 0xC4, 0x1F, 0xF4, 0x5C,
111 0x4E, 0xE6, 0x99, 0x30, 0xE0, 0x42, 0x88, 0xAB,
112 0xE5, 0x85, 0xBC, 0x8F, 0xD8, 0x3C, 0x54, 0xC9,
113 0x53, 0x47, 0x18, 0xD6, 0x06, 0x5B, 0x41, 0x2C,
114 0x67, 0x1E, 0x41, 0x74, 0x33, 0xE2, 0xB4, 0xE0,
115 0x23, 0x29, 0x42, 0xEA, 0x55, 0x0F, 0x25, 0xB4,
116 0x24, 0x2C, 0x99, 0x13, 0xEB, 0x0A, 0x0B, 0xC9,
117 0xF9, 0x63, 0x67, 0x43, 0x2D, 0xC7, 0x7D, 0x07,
118 0x60, 0x89, 0xD1, 0xCC, 0xE7, 0x94, 0x77, 0x74,
119 0x9B, 0x7E, 0xD7, 0xE6, 0xFF, 0xBB, 0x68, 0x14,
120 0x1E, 0xA3, 0x25, 0xDE, 0x3A, 0xA3, 0x54, 0x7B,
121 0x87, 0x9D, 0x50, 0xCA, 0x27, 0xC3, 0xA4, 0x50,
122 0x91, 0x27, 0xD4, 0xB0, 0x82, 0x41, 0x97, 0x79,
123 0x94, 0x82, 0xAC, 0xC7, 0x8E, 0xA5, 0x4E, 0xAA,
124 0x78, 0x9E, 0xE0, 0x42, 0xBA, 0x28, 0xEA, 0xB7,
125 0x74, 0xAD, 0x35, 0xDA, 0x92, 0x60, 0x7E, 0xD2,
126 0x0E, 0xB9, 0x24, 0x5E, 0x39, 0x4F, 0x5E, 0x63,
127 0x09, 0xB5, 0xFA, 0xBF, 0xF1, 0x22, 0x55, 0x1C,
128 0xE2, 0x25, 0xDB, 0xC5, 0xD8, 0x50, 0x03, 0x98,
129 0xC4, 0xAC, 0x2E, 0x11, 0xB4, 0x38, 0x4D, 0xD0,
130 0xB9, 0xFC, 0x2D, 0x3C, 0x08, 0x04, 0x5A, 0xEF,
131 0xCE, 0x32, 0xFB, 0x4C, 0x92, 0x1E, 0x4B, 0xFB,
132 0x1A, 0xD0, 0xE2, 0x3E, 0xDA, 0x6E, 0x7C, 0x4D,
133 0x56, 0xC3, 0x3F, 0x42, 0xB1, 0x3A, 0x23, 0x4D,
134 0x6E, 0x84, 0x56, 0x68, 0xF4, 0x0E, 0x03, 0x64,
135 0xD0, 0xA9, 0x92, 0x2F, 0x8B, 0xBC, 0x39, 0x9C,
136 0xAC, 0x09, 0x5E, 0xEE, 0xE5, 0x97, 0xBF, 0xA5,
137 0xCE, 0xFA, 0x28, 0x2C, 0x6D, 0x4F, 0xEF, 0x77,
138 0xAA, 0x1B, 0x79, 0x8E, 0x97, 0xB4, 0xC3, 0xF4
141 static unsigned char mpeg3css_table2[] =
143 0xB7, 0x75, 0x81, 0xD5, 0xDC, 0xCA, 0xDE, 0x66,
144 0x23, 0xDF, 0x15, 0x26, 0x62, 0xD1, 0x83, 0x77,
145 0xE3, 0x97, 0x76, 0xAF, 0xE9, 0xC3, 0x6B, 0x8E,
146 0xDA, 0xB0, 0x6E, 0xBF, 0x2B, 0xF1, 0x19, 0xB4,
147 0x95, 0x34, 0x48, 0xE4, 0x37, 0x94, 0x5D, 0x7B,
148 0x36, 0x5F, 0x65, 0x53, 0x07, 0xE2, 0x89, 0x11,
149 0x98, 0x85, 0xD9, 0x12, 0xC1, 0x9D, 0x84, 0xEC,
150 0xA4, 0xD4, 0x88, 0xB8, 0xFC, 0x2C, 0x79, 0x28,
151 0xD8, 0xDB, 0xB3, 0x1E, 0xA2, 0xF9, 0xD0, 0x44,
152 0xD7, 0xD6, 0x60, 0xEF, 0x14, 0xF4, 0xF6, 0x31,
153 0xD2, 0x41, 0x46, 0x67, 0x0A, 0xE1, 0x58, 0x27,
154 0x43, 0xA3, 0xF8, 0xE0, 0xC8, 0xBA, 0x5A, 0x5C,
155 0x80, 0x6C, 0xC6, 0xF2, 0xE8, 0xAD, 0x7D, 0x04,
156 0x0D, 0xB9, 0x3C, 0xC2, 0x25, 0xBD, 0x49, 0x63,
157 0x8C, 0x9F, 0x51, 0xCE, 0x20, 0xC5, 0xA1, 0x50,
158 0x92, 0x2D, 0xDD, 0xBC, 0x8D, 0x4F, 0x9A, 0x71,
159 0x2F, 0x30, 0x1D, 0x73, 0x39, 0x13, 0xFB, 0x1A,
160 0xCB, 0x24, 0x59, 0xFE, 0x05, 0x96, 0x57, 0x0F,
161 0x1F, 0xCF, 0x54, 0xBE, 0xF5, 0x06, 0x1B, 0xB2,
162 0x6D, 0xD3, 0x4D, 0x32, 0x56, 0x21, 0x33, 0x0B,
163 0x52, 0xE7, 0xAB, 0xEB, 0xA6, 0x74, 0x00, 0x4C,
164 0xB1, 0x7F, 0x82, 0x99, 0x87, 0x0E, 0x5E, 0xC0,
165 0x8F, 0xEE, 0x6F, 0x55, 0xF3, 0x7E, 0x08, 0x90,
166 0xFA, 0xB6, 0x64, 0x70, 0x47, 0x4A, 0x17, 0xA7,
167 0xB5, 0x40, 0x8A, 0x38, 0xE5, 0x68, 0x3E, 0x8B,
168 0x69, 0xAA, 0x9B, 0x42, 0xA5, 0x10, 0x01, 0x35,
169 0xFD, 0x61, 0x9E, 0xE6, 0x16, 0x9C, 0x86, 0xED,
170 0xCD, 0x2E, 0xFF, 0xC4, 0x5B, 0xA0, 0xAE, 0xCC,
171 0x4B, 0x3B, 0x03, 0xBB, 0x1C, 0x2A, 0xAC, 0x0C,
172 0x3F, 0x93, 0xC7, 0x72, 0x7A, 0x09, 0x22, 0x3D,
173 0x45, 0x78, 0xA9, 0xA8, 0xEA, 0xC9, 0x6A, 0xF7,
174 0x29, 0x91, 0xF0, 0x02, 0x18, 0x3A, 0x4E, 0x7C
177 static unsigned char mpeg3css_table3[] =
179 0x73, 0x51, 0x95, 0xE1, 0x12, 0xE4, 0xC0, 0x58,
180 0xEE, 0xF2, 0x08, 0x1B, 0xA9, 0xFA, 0x98, 0x4C,
181 0xA7, 0x33, 0xE2, 0x1B, 0xA7, 0x6D, 0xF5, 0x30,
182 0x97, 0x1D, 0xF3, 0x02, 0x60, 0x5A, 0x82, 0x0F,
183 0x91, 0xD0, 0x9C, 0x10, 0x39, 0x7A, 0x83, 0x85,
184 0x3B, 0xB2, 0xB8, 0xAE, 0x0C, 0x09, 0x52, 0xEA,
185 0x1C, 0xE1, 0x8D, 0x66, 0x4F, 0xF3, 0xDA, 0x92,
186 0x29, 0xB9, 0xD5, 0xC5, 0x77, 0x47, 0x22, 0x53,
187 0x14, 0xF7, 0xAF, 0x22, 0x64, 0xDF, 0xC6, 0x72,
188 0x12, 0xF3, 0x75, 0xDA, 0xD7, 0xD7, 0xE5, 0x02,
189 0x9E, 0xED, 0xDA, 0xDB, 0x4C, 0x47, 0xCE, 0x91,
190 0x06, 0x06, 0x6D, 0x55, 0x8B, 0x19, 0xC9, 0xEF,
191 0x8C, 0x80, 0x1A, 0x0E, 0xEE, 0x4B, 0xAB, 0xF2,
192 0x08, 0x5C, 0xE9, 0x37, 0x26, 0x5E, 0x9A, 0x90,
193 0x00, 0xF3, 0x0D, 0xB2, 0xA6, 0xA3, 0xF7, 0x26,
194 0x17, 0x48, 0x88, 0xC9, 0x0E, 0x2C, 0xC9, 0x02,
195 0xE7, 0x18, 0x05, 0x4B, 0xF3, 0x39, 0xE1, 0x20,
196 0x02, 0x0D, 0x40, 0xC7, 0xCA, 0xB9, 0x48, 0x30,
197 0x57, 0x67, 0xCC, 0x06, 0xBF, 0xAC, 0x81, 0x08,
198 0x24, 0x7A, 0xD4, 0x8B, 0x19, 0x8E, 0xAC, 0xB4,
199 0x5A, 0x0F, 0x73, 0x13, 0xAC, 0x9E, 0xDA, 0xB6,
200 0xB8, 0x96, 0x5B, 0x60, 0x88, 0xE1, 0x81, 0x3F,
201 0x07, 0x86, 0x37, 0x2D, 0x79, 0x14, 0x52, 0xEA,
202 0x73, 0xDF, 0x3D, 0x09, 0xC8, 0x25, 0x48, 0xD8,
203 0x75, 0x60, 0x9A, 0x08, 0x27, 0x4A, 0x2C, 0xB9,
204 0xA8, 0x8B, 0x8A, 0x73, 0x62, 0x37, 0x16, 0x02,
205 0xBD, 0xC1, 0x0E, 0x56, 0x54, 0x3E, 0x14, 0x5F,
206 0x8C, 0x8F, 0x6E, 0x75, 0x1C, 0x07, 0x39, 0x7B,
207 0x4B, 0xDB, 0xD3, 0x4B, 0x1E, 0xC8, 0x7E, 0xFE,
208 0x3E, 0x72, 0x16, 0x83, 0x7D, 0xEE, 0xF5, 0xCA,
209 0xC5, 0x18, 0xF9, 0xD8, 0x68, 0xAB, 0x38, 0x85,
210 0xA8, 0xF0, 0xA1, 0x73, 0x9F, 0x5D, 0x19, 0x0B,
211 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
212 0x33, 0x72, 0x39, 0x25, 0x67, 0x26, 0x6D, 0x71,
213 0x36, 0x77, 0x3C, 0x20, 0x62, 0x23, 0x68, 0x74,
214 0xC3, 0x82, 0xC9, 0x15, 0x57, 0x16, 0x5D, 0x81
217 static struct mpeg3_playkey mpeg3_pkey1a1 = {0x36b, {0x51,0x67,0x67,0xc5,0xe0}};
218 static struct mpeg3_playkey mpeg3_pkey2a1 = {0x762, {0x2c,0xb2,0xc1,0x09,0xee}};
219 static struct mpeg3_playkey mpeg3_pkey1b1 = {0x36b, {0x90,0xc1,0xd7,0x84,0x48}};
221 static struct mpeg3_playkey mpeg3_pkey1a2 = {0x2f3, {0x51,0x67,0x67,0xc5,0xe0}};
222 static struct mpeg3_playkey mpeg3_pkey2a2 = {0x730, {0x2c,0xb2,0xc1,0x09,0xee}};
223 static struct mpeg3_playkey mpeg3_pkey1b2 = {0x2f3, {0x90,0xc1,0xd7,0x84,0x48}};
225 static struct mpeg3_playkey mpeg3_pkey1a3 = {0x235, {0x51,0x67,0x67,0xc5,0xe0}};
226 static struct mpeg3_playkey mpeg3_pkey1b3 = {0x235, {0x90,0xc1,0xd7,0x84,0x48}};
228 static struct mpeg3_playkey mpeg3_pkey3a1 = {0x249, {0xb7,0x3f,0xd4,0xaa,0x14}}; /* DVD specific ? */
229 static struct mpeg3_playkey mpeg3_pkey4a1 = {0x028, {0x53,0xd4,0xf7,0xd9,0x8f}}; /* DVD specific ? */
231 static struct mpeg3_playkey *mpeg3_playkeys[] =
233 &mpeg3_pkey1a1, &mpeg3_pkey2a1, &mpeg3_pkey1b1,
234 &mpeg3_pkey1a2, &mpeg3_pkey2a2, &mpeg3_pkey1b2,
235 &mpeg3_pkey1a3, &mpeg3_pkey1b3,
236 &mpeg3_pkey3a1, &mpeg3_pkey4a1,
237 NULL
242 * some tables used for descrambling sectors and/or decrypting title keys
246 static unsigned char csstab1[256]=
248 0x33,0x73,0x3b,0x26,0x63,0x23,0x6b,0x76,0x3e,0x7e,0x36,0x2b,0x6e,0x2e,0x66,0x7b,
249 0xd3,0x93,0xdb,0x06,0x43,0x03,0x4b,0x96,0xde,0x9e,0xd6,0x0b,0x4e,0x0e,0x46,0x9b,
250 0x57,0x17,0x5f,0x82,0xc7,0x87,0xcf,0x12,0x5a,0x1a,0x52,0x8f,0xca,0x8a,0xc2,0x1f,
251 0xd9,0x99,0xd1,0x00,0x49,0x09,0x41,0x90,0xd8,0x98,0xd0,0x01,0x48,0x08,0x40,0x91,
252 0x3d,0x7d,0x35,0x24,0x6d,0x2d,0x65,0x74,0x3c,0x7c,0x34,0x25,0x6c,0x2c,0x64,0x75,
253 0xdd,0x9d,0xd5,0x04,0x4d,0x0d,0x45,0x94,0xdc,0x9c,0xd4,0x05,0x4c,0x0c,0x44,0x95,
254 0x59,0x19,0x51,0x80,0xc9,0x89,0xc1,0x10,0x58,0x18,0x50,0x81,0xc8,0x88,0xc0,0x11,
255 0xd7,0x97,0xdf,0x02,0x47,0x07,0x4f,0x92,0xda,0x9a,0xd2,0x0f,0x4a,0x0a,0x42,0x9f,
256 0x53,0x13,0x5b,0x86,0xc3,0x83,0xcb,0x16,0x5e,0x1e,0x56,0x8b,0xce,0x8e,0xc6,0x1b,
257 0xb3,0xf3,0xbb,0xa6,0xe3,0xa3,0xeb,0xf6,0xbe,0xfe,0xb6,0xab,0xee,0xae,0xe6,0xfb,
258 0x37,0x77,0x3f,0x22,0x67,0x27,0x6f,0x72,0x3a,0x7a,0x32,0x2f,0x6a,0x2a,0x62,0x7f,
259 0xb9,0xf9,0xb1,0xa0,0xe9,0xa9,0xe1,0xf0,0xb8,0xf8,0xb0,0xa1,0xe8,0xa8,0xe0,0xf1,
260 0x5d,0x1d,0x55,0x84,0xcd,0x8d,0xc5,0x14,0x5c,0x1c,0x54,0x85,0xcc,0x8c,0xc4,0x15,
261 0xbd,0xfd,0xb5,0xa4,0xed,0xad,0xe5,0xf4,0xbc,0xfc,0xb4,0xa5,0xec,0xac,0xe4,0xf5,
262 0x39,0x79,0x31,0x20,0x69,0x29,0x61,0x70,0x38,0x78,0x30,0x21,0x68,0x28,0x60,0x71,
263 0xb7,0xf7,0xbf,0xa2,0xe7,0xa7,0xef,0xf2,0xba,0xfa,0xb2,0xaf,0xea,0xaa,0xe2,0xff
266 static unsigned char lfsr1_bits0[256]=
268 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x09,0x08,0x0b,0x0a,0x0d,0x0c,0x0f,0x0e,
269 0x12,0x13,0x10,0x11,0x16,0x17,0x14,0x15,0x1b,0x1a,0x19,0x18,0x1f,0x1e,0x1d,0x1c,
270 0x24,0x25,0x26,0x27,0x20,0x21,0x22,0x23,0x2d,0x2c,0x2f,0x2e,0x29,0x28,0x2b,0x2a,
271 0x36,0x37,0x34,0x35,0x32,0x33,0x30,0x31,0x3f,0x3e,0x3d,0x3c,0x3b,0x3a,0x39,0x38,
272 0x49,0x48,0x4b,0x4a,0x4d,0x4c,0x4f,0x4e,0x40,0x41,0x42,0x43,0x44,0x45,0x46,0x47,
273 0x5b,0x5a,0x59,0x58,0x5f,0x5e,0x5d,0x5c,0x52,0x53,0x50,0x51,0x56,0x57,0x54,0x55,
274 0x6d,0x6c,0x6f,0x6e,0x69,0x68,0x6b,0x6a,0x64,0x65,0x66,0x67,0x60,0x61,0x62,0x63,
275 0x7f,0x7e,0x7d,0x7c,0x7b,0x7a,0x79,0x78,0x76,0x77,0x74,0x75,0x72,0x73,0x70,0x71,
276 0x92,0x93,0x90,0x91,0x96,0x97,0x94,0x95,0x9b,0x9a,0x99,0x98,0x9f,0x9e,0x9d,0x9c,
277 0x80,0x81,0x82,0x83,0x84,0x85,0x86,0x87,0x89,0x88,0x8b,0x8a,0x8d,0x8c,0x8f,0x8e,
278 0xb6,0xb7,0xb4,0xb5,0xb2,0xb3,0xb0,0xb1,0xbf,0xbe,0xbd,0xbc,0xbb,0xba,0xb9,0xb8,
279 0xa4,0xa5,0xa6,0xa7,0xa0,0xa1,0xa2,0xa3,0xad,0xac,0xaf,0xae,0xa9,0xa8,0xab,0xaa,
280 0xdb,0xda,0xd9,0xd8,0xdf,0xde,0xdd,0xdc,0xd2,0xd3,0xd0,0xd1,0xd6,0xd7,0xd4,0xd5,
281 0xc9,0xc8,0xcb,0xca,0xcd,0xcc,0xcf,0xce,0xc0,0xc1,0xc2,0xc3,0xc4,0xc5,0xc6,0xc7,
282 0xff,0xfe,0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf6,0xf7,0xf4,0xf5,0xf2,0xf3,0xf0,0xf1,
283 0xed,0xec,0xef,0xee,0xe9,0xe8,0xeb,0xea,0xe4,0xe5,0xe6,0xe7,0xe0,0xe1,0xe2,0xe3
286 static unsigned char lfsr1_bits1[512]=
288 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
289 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
290 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
291 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
292 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
293 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
294 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
295 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
296 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
297 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
298 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
299 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
300 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
301 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
302 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
303 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
304 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
305 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
306 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
307 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
308 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
309 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
310 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
311 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
312 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
313 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
314 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
315 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
316 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
317 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
318 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,
319 0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff,0x00,0x24,0x49,0x6d,0x92,0xb6,0xdb,0xff
322 /* Reverse the order of the bits within a byte.
324 static unsigned char bit_reverse[256]=
326 0x00,0x80,0x40,0xc0,0x20,0xa0,0x60,0xe0,0x10,0x90,0x50,0xd0,0x30,0xb0,0x70,0xf0,
327 0x08,0x88,0x48,0xc8,0x28,0xa8,0x68,0xe8,0x18,0x98,0x58,0xd8,0x38,0xb8,0x78,0xf8,
328 0x04,0x84,0x44,0xc4,0x24,0xa4,0x64,0xe4,0x14,0x94,0x54,0xd4,0x34,0xb4,0x74,0xf4,
329 0x0c,0x8c,0x4c,0xcc,0x2c,0xac,0x6c,0xec,0x1c,0x9c,0x5c,0xdc,0x3c,0xbc,0x7c,0xfc,
330 0x02,0x82,0x42,0xc2,0x22,0xa2,0x62,0xe2,0x12,0x92,0x52,0xd2,0x32,0xb2,0x72,0xf2,
331 0x0a,0x8a,0x4a,0xca,0x2a,0xaa,0x6a,0xea,0x1a,0x9a,0x5a,0xda,0x3a,0xba,0x7a,0xfa,
332 0x06,0x86,0x46,0xc6,0x26,0xa6,0x66,0xe6,0x16,0x96,0x56,0xd6,0x36,0xb6,0x76,0xf6,
333 0x0e,0x8e,0x4e,0xce,0x2e,0xae,0x6e,0xee,0x1e,0x9e,0x5e,0xde,0x3e,0xbe,0x7e,0xfe,
334 0x01,0x81,0x41,0xc1,0x21,0xa1,0x61,0xe1,0x11,0x91,0x51,0xd1,0x31,0xb1,0x71,0xf1,
335 0x09,0x89,0x49,0xc9,0x29,0xa9,0x69,0xe9,0x19,0x99,0x59,0xd9,0x39,0xb9,0x79,0xf9,
336 0x05,0x85,0x45,0xc5,0x25,0xa5,0x65,0xe5,0x15,0x95,0x55,0xd5,0x35,0xb5,0x75,0xf5,
337 0x0d,0x8d,0x4d,0xcd,0x2d,0xad,0x6d,0xed,0x1d,0x9d,0x5d,0xdd,0x3d,0xbd,0x7d,0xfd,
338 0x03,0x83,0x43,0xc3,0x23,0xa3,0x63,0xe3,0x13,0x93,0x53,0xd3,0x33,0xb3,0x73,0xf3,
339 0x0b,0x8b,0x4b,0xcb,0x2b,0xab,0x6b,0xeb,0x1b,0x9b,0x5b,0xdb,0x3b,0xbb,0x7b,0xfb,
340 0x07,0x87,0x47,0xc7,0x27,0xa7,0x67,0xe7,0x17,0x97,0x57,0xd7,0x37,0xb7,0x77,0xf7,
341 0x0f,0x8f,0x4f,0xcf,0x2f,0xaf,0x6f,0xef,0x1f,0x9f,0x5f,0xdf,0x3f,0xbf,0x7f,0xff
344 /* ================================= Functions ====================================== */
347 * We use two LFSR's (seeded from some of the input data bytes) to
348 * generate two streams of pseudo-random bits. These two bit streams
349 * are then combined by simply adding with carry to generate a final
350 * sequence of pseudo-random bits which is stored in the buffer that
351 * 'output' points to the end of - len is the size of this buffer.
353 * The first LFSR is of degree 25, and has a polynomial of:
354 * x^13 + x^5 + x^4 + x^1 + 1
356 * The second LSFR is of degree 17, and has a (primitive) polynomial of:
357 * x^15 + x^1 + 1
359 * I don't know if these polynomials are primitive modulo 2, and thus
360 * represent maximal-period LFSR's.
363 * Note that we take the output of each LFSR from the new shifted in
364 * bit, not the old shifted out bit. Thus for ease of use the LFSR's
365 * are implemented in bit reversed order.
369 #define BIT0(x) ((x) & 1)
370 #define BIT1(x) (((x) >> 1) & 1)
372 static void generate_bits(unsigned char *output, int len, struct mpeg3_block const *s)
374 unsigned long lfsr0, lfsr1;
375 unsigned char carry;
377 /* In order to ensure that the LFSR works we need to ensure that the
378 * initial values are non-zero. Thus when we initialise them from
379 * the seed, we ensure that a bit is set.
381 lfsr0 = (s->b[0] << 17) | (s->b[1] << 9) | ((s->b[2] & ~7) << 1) | 8 | (s->b[2] & 7);
382 lfsr1 = (s->b[3] << 9) | 0x100 | s->b[4];
384 ++output;
386 carry = 0;
388 int bit;
389 unsigned char val;
391 for (bit = 0, val = 0; bit < 8; ++bit)
393 unsigned char o_lfsr0, o_lfsr1; /* Actually only 1 bit each */
394 unsigned char combined;
396 o_lfsr0 = ((lfsr0 >> 24) ^ (lfsr0 >> 21) ^ (lfsr0 >> 20) ^ (lfsr0 >> 12)) & 1;
397 lfsr0 = (lfsr0 << 1) | o_lfsr0;
399 o_lfsr1 = ((lfsr1 >> 16) ^ (lfsr1 >> 2)) & 1;
400 lfsr1 = (lfsr1 << 1) | o_lfsr1;
402 combined = !o_lfsr1 + carry + !o_lfsr0;
403 carry = BIT1(combined);
404 val |= BIT0(combined) << bit;
407 *--output = val;
408 }while (--len > 0);
413 * This encryption engine implements one of 32 variations
414 * one the same theme depending upon the choice in the
415 * varient parameter (0 - 31).
417 * The algorithm itself manipulates a 40 bit input into
418 * a 40 bit output.
419 * The parameter 'input' is 80 bits. It consists of
420 * the 40 bit input value that is to be encrypted followed
421 * by a 40 bit seed value for the pseudo random number
422 * generators.
424 static void css_engine(int varient, unsigned char const *input, struct mpeg3_block *output)
426 unsigned char cse, term, index;
427 struct mpeg3_block temp1;
428 struct mpeg3_block temp2;
429 unsigned char bits[30];
431 int i;
433 /* Feed the secret into the input values such that
434 * we alter the seed to the LFSR's used above, then
435 * generate the bits to play with.
437 for(i = 5; --i >= 0; )
438 temp1.b[i] = input[5 + i] ^ mpeg3css_secret[i] ^ mpeg3css_table2[i];
440 generate_bits(&bits[29], sizeof bits, &temp1);
442 /* This term is used throughout the following to
443 * select one of 32 different variations on the
444 * algorithm.
446 cse = mpeg3css_varients[varient] ^ mpeg3css_table2[varient];
448 /* Now the actual blocks doing the encryption. Each
449 * of these works on 40 bits at a time and are quite
450 * similar.
452 for(i = 5, term = 0; --i >= 0; term = input[i])
454 index = bits[25 + i] ^ input[i];
455 index = mpeg3css_table1[index] ^ ~mpeg3css_table2[index] ^ cse;
457 temp1.b[i] = mpeg3css_table2[index] ^ mpeg3css_table3[index] ^ term;
459 temp1.b[4] ^= temp1.b[0];
461 for(i = 5, term = 0; --i >= 0; term = temp1.b[i])
463 index = bits[20 + i] ^ temp1.b[i];
464 index = mpeg3css_table1[index] ^ ~mpeg3css_table2[index] ^ cse;
466 temp2.b[i] = mpeg3css_table2[index] ^ mpeg3css_table3[index] ^ term;
468 temp2.b[4] ^= temp2.b[0];
470 for (i = 5, term = 0; --i >= 0; term = temp2.b[i])
472 index = bits[15 + i] ^ temp2.b[i];
473 index = mpeg3css_table1[index] ^ ~mpeg3css_table2[index] ^ cse;
474 index = mpeg3css_table2[index] ^ mpeg3css_table3[index] ^ term;
476 temp1.b[i] = mpeg3css_table0[index] ^ mpeg3css_table2[index];
478 temp1.b[4] ^= temp1.b[0];
480 for (i = 5, term = 0; --i >= 0; term = temp1.b[i])
482 index = bits[10 + i] ^ temp1.b[i];
483 index = mpeg3css_table1[index] ^ ~mpeg3css_table2[index] ^ cse;
485 index = mpeg3css_table2[index] ^ mpeg3css_table3[index] ^ term;
487 temp2.b[i] = mpeg3css_table0[index] ^ mpeg3css_table2[index];
489 temp2.b[4] ^= temp2.b[0];
491 for (i = 5, term = 0; --i >= 0; term = temp2.b[i])
493 index = bits[5 + i] ^ temp2.b[i];
494 index = mpeg3css_table1[index] ^ ~mpeg3css_table2[index] ^ cse;
496 temp1.b[i] = mpeg3css_table2[index] ^ mpeg3css_table3[index] ^ term;
498 temp1.b[4] ^= temp1.b[0];
500 for (i = 5, term = 0; --i >= 0; term = temp1.b[i])
502 index = bits[i] ^ temp1.b[i];
503 index = mpeg3css_table1[index] ^ ~mpeg3css_table2[index] ^ cse;
505 output->b[i] = mpeg3css_table2[index] ^ mpeg3css_table3[index] ^ term;
509 static void crypt_key1(mpeg3_css_t *css, int varient, unsigned char const *challenge, struct mpeg3_block *key)
511 static unsigned char perm_challenge[] = {1, 3, 0, 7, 5, 2, 9, 6, 4, 8};
513 unsigned char scratch[10];
514 int i;
516 for (i = 9; i >= 0; i--)
517 scratch[i] = challenge[perm_challenge[i]];
519 css_engine(varient, scratch, key);
522 /* This shuffles the bits in varient to make perm_varient such that
523 * 4 -> !3
524 * 3 -> 4
525 * varient bits: 2 -> 0 perm_varient bits
526 * 1 -> 2
527 * 0 -> !1
529 static void crypt_key2(mpeg3_css_t *css, int varient, unsigned char const *challenge, struct mpeg3_block *key)
531 static unsigned char perm_challenge[] = {6, 1, 9, 3, 8, 5, 7, 4, 0, 2};
533 static unsigned char perm_varient[] =
535 0x0a, 0x08, 0x0e, 0x0c, 0x0b, 0x09, 0x0f, 0x0d,
536 0x1a, 0x18, 0x1e, 0x1c, 0x1b, 0x19, 0x1f, 0x1d,
537 0x02, 0x00, 0x06, 0x04, 0x03, 0x01, 0x07, 0x05,
538 0x12, 0x10, 0x16, 0x14, 0x13, 0x11, 0x17, 0x15
541 unsigned char scratch[10];
542 int i;
544 for(i = 9; i >= 0; i--)
545 scratch[i] = css->challenge[perm_challenge[i]];
547 css_engine(perm_varient[varient], scratch, key);
550 /* This shuffles the bits in varient to make perm_varient such that
551 * 4 -> 0
552 * 3 -> !1
553 * varient bits: 2 -> !4 perm_varient bits
554 * 1 -> 2
555 * 0 -> 3
557 static void crypt_bus_key(mpeg3_css_t *css, int varient, unsigned char const *challenge, struct mpeg3_block *key)
559 static unsigned char perm_challenge[] = {4,0,3,5,7, 2,8,6,1,9};
560 static unsigned char perm_varient[] = {
561 0x12, 0x1a, 0x16, 0x1e, 0x02, 0x0a, 0x06, 0x0e,
562 0x10, 0x18, 0x14, 0x1c, 0x00, 0x08, 0x04, 0x0c,
563 0x13, 0x1b, 0x17, 0x1f, 0x03, 0x0b, 0x07, 0x0f,
564 0x11, 0x19, 0x15, 0x1d, 0x01, 0x09, 0x05, 0x0d};
566 unsigned char scratch[10];
567 int i;
569 for(i = 9; i >= 0; i--)
570 scratch[i] = css->challenge[perm_challenge[i]];
572 css_engine(perm_varient[varient], scratch, key);
575 static int get_asf(mpeg3_css_t *css)
577 dvd_authinfo ai;
579 ai.type = DVD_LU_SEND_ASF;
580 ai.lsasf.agid = 0;
581 ai.lsasf.asf = 0;
583 if(ioctl(css->fd, DVD_AUTH, &ai))
585 /* Exit here for a hard drive or unencrypted CD-ROM. */
586 return 1;
589 return 0;
592 static int authenticate_drive(mpeg3_css_t *css, const unsigned char *key)
594 int i;
596 for(i = 0; i < 5; i++)
597 css->key1.b[i] = key[4 - i];
599 for(i = 0; i < 32; ++i)
601 crypt_key1(css, i, css->challenge, &(css->keycheck));
602 if(memcmp(css->keycheck.b, css->key1.b, 5) == 0)
604 css->varient = i;
605 return 0;
609 if (css->varient == -1) return 1;
611 return 0;
614 /* Simulation of a non-CSS compliant host (i.e. the authentication fails,
615 * but idea is here for a real CSS compliant authentication scheme). */
616 static int hostauth(mpeg3_css_t *css, dvd_authinfo *ai)
618 int i;
620 switch(ai->type)
622 /* Host data receive (host changes state) */
623 case DVD_LU_SEND_AGID:
624 ai->type = DVD_HOST_SEND_CHALLENGE;
625 break;
627 case DVD_LU_SEND_KEY1:
628 /* printf("Key 1: %02x %02x %02x %02x %02x\n", */
629 /* ai->lsk.key[4], ai->lsk.key[3], ai->lsk.key[2], ai->lsk.key[1], ai->lsk.key[0]); */
630 if(authenticate_drive(css, ai->lsk.key))
632 ai->type = DVD_AUTH_FAILURE;
633 return 1;
635 ai->type = DVD_LU_SEND_CHALLENGE;
636 break;
638 case DVD_LU_SEND_CHALLENGE:
639 for(i = 0; i < 10; i++)
640 css->challenge[i] = ai->hsc.chal[9-i];
641 crypt_key2(css, css->varient, css->challenge, &(css->key2));
642 ai->type = DVD_HOST_SEND_KEY2;
643 break;
645 /* Host data send */
646 case DVD_HOST_SEND_CHALLENGE:
647 for(i = 0; i < 10; i++)
648 ai->hsc.chal[9 - i] = css->challenge[i];
649 /* Returning data, let LU change state */
650 break;
652 case DVD_HOST_SEND_KEY2:
653 for(i = 0; i < 5; i++)
655 ai->hsk.key[4 - i] = css->key2.b[i];
657 /* printf("Key 2: %02x %02x %02x %02x %02x\n", */
658 /* ai->hsk.key[4], ai->hsk.key[3], ai->hsk.key[2], ai->hsk.key[1], ai->hsk.key[0]); */
659 /* Returning data, let LU change state */
660 break;
662 default:
663 fprintf(stderr, "Got invalid state %d\n", ai->type);
664 return 1;
667 return 0;
670 static int get_title_key(mpeg3_css_t *css, int agid, int lba, unsigned char *key)
672 dvd_authinfo ai;
673 int i;
675 ai.type = DVD_LU_SEND_TITLE_KEY;
677 ai.lstk.agid = agid;
678 ai.lstk.lba = lba;
680 if(ioctl(css->fd, DVD_AUTH, &ai))
682 //perror("GetTitleKey");
683 return 1;
686 for (i = 0; i < 5; i++)
688 ai.lstk.title_key[i] ^= key[4 - (i % 5)];
691 /* Save the title key */
692 for(i = 0; i < 5; i++)
694 css->title_key[i] = ai.lstk.title_key[i];
697 return 0;
700 static int get_disk_key(mpeg3_css_t *css, int agid, unsigned char *key)
702 dvd_struct s;
703 int index, i;
705 s.type = DVD_STRUCT_DISCKEY;
706 s.disckey.agid = agid;
707 memset(s.disckey.value, 0, MPEG3_DVD_PACKET_SIZE);
708 if(ioctl(css->fd, DVD_READ_STRUCT, &s) < 0)
710 /*perror("get_disk_key"); */
711 return 1;
714 for(index = 0; index < sizeof s.disckey.value; index ++)
715 s.disckey.value[index] ^= key[4 - (index%5)];
717 /* Save disk key */
718 for(i = 0; i < MPEG3_DVD_PACKET_SIZE; i++)
719 css->disk_key[i] = s.disckey.value[i];
721 return 0;
724 static int validate(mpeg3_css_t *css, int lba, int do_title)
726 dvd_authinfo ai;
727 dvd_struct dvds;
728 int result = 0;
729 int i, rv, tries, agid;
731 memset(&ai, 0, sizeof (ai));
732 memset(&dvds, 0, sizeof (dvds));
734 if(get_asf(css)) return 1;
736 /* Init sequence, request AGID */
737 for(tries = 1, rv = -1; rv == -1 && tries < 4; tries++)
739 ai.type = DVD_LU_SEND_AGID;
740 ai.lsa.agid = 0;
741 rv = ioctl(css->fd, DVD_AUTH, &ai);
742 if(rv == -1)
744 /* perror("validate: request AGID"); */
745 ai.type = DVD_INVALIDATE_AGID;
746 ai.lsa.agid = 0;
747 ioctl(css->fd, DVD_AUTH, &ai);
750 if(tries >= 4) return 1;
752 for(i = 0; i < 10; i++) css->challenge[i] = i;
754 /* Send AGID to host */
755 if(hostauth(css, &ai)) return 1;
757 /* Get challenge from host */
758 if(hostauth(css, &ai)) return 1;
759 agid = ai.lsa.agid;
761 /* Send challenge to LU */
762 if(ioctl(css->fd, DVD_AUTH, &ai) < 0) return 1;
764 /* Get key1 from LU */
765 if(ioctl(css->fd, DVD_AUTH, &ai) < 0) return 1;
767 /* Send key1 to host */
768 if(hostauth(css, &ai)) return 1;
770 /* Get challenge from LU */
771 if(ioctl(css->fd, DVD_AUTH, &ai) < 0) return 1;
773 /* Send challenge to host */
774 if(hostauth(css, &ai)) return 1;
776 /* Get key2 from host */
777 if(hostauth(css, &ai)) return 1;
779 /* Send key2 to LU */
780 if(ioctl(css->fd, DVD_AUTH, &ai) < 0)
782 perror("validate: Send key2 to LU");
783 return 1;
786 if(ai.type == DVD_AUTH_FAILURE)
788 fprintf(stderr, "validate: authorization failed\n");
789 return 1;
791 memcpy(css->challenge, css->key1.b, 5);
792 memcpy(css->challenge + 5, css->key2.b, 5);
793 crypt_bus_key(css, css->varient, css->challenge, &(css->keycheck));
795 get_asf(css);
797 if(do_title)
798 return get_title_key(css, agid, lba, css->keycheck.b);
799 else
800 return get_disk_key(css, agid, css->keycheck.b);
802 return 0;
805 static int validate_path(mpeg3_css_t *css, int do_title)
807 int result = 0;
808 int lba = 0, file_fd;
810 if(do_title)
812 if((file_fd = open(css->path, O_RDONLY)) == -1)
814 perror("validate_path: open");
815 return 1;
818 if(ioctl(file_fd, FIBMAP, &lba) != 0)
820 perror("validate_path: FIBMAP");
821 close(file_fd);
822 return 1;
825 close(file_fd);
828 result = mpeg3io_device(css->path, css->device_path);
830 //printf("validate_path 1 %d\n", result);
831 if(!result) result = (css->fd = open(css->device_path, O_RDONLY | O_NONBLOCK)) < 0;
832 //printf("validate_path 2 %d\n", result);
834 if(!result) result = validate(css, lba, do_title);
836 //printf("validate_path 3 %d\n", result);
837 /* Definitely encrypted if we got here. */
840 if(!result) css->encrypted = 1;
842 close(css->fd);
843 return result;
848 * this function is only used internally when decrypting title key
851 static void title_key(unsigned char *key, unsigned char *im, unsigned char invert)
853 unsigned int lfsr1_lo, lfsr1_hi, lfsr0, combined;
854 unsigned char o_lfsr0, o_lfsr1;
855 unsigned char k[5];
856 int i;
858 lfsr1_lo = im[0] | 0x100;
859 lfsr1_hi = im[1];
861 lfsr0 = ((im[4] << 17) | (im[3] << 9) | (im[2] << 1)) + 8 - (im[2]&7);
862 lfsr0 = (bit_reverse[lfsr0 & 0xff] << 24) | (bit_reverse[(lfsr0 >> 8) & 0xff] << 16)
863 | (bit_reverse[(lfsr0 >> 16) & 0xff] << 8) | bit_reverse[(lfsr0 >> 24) & 0xff];
865 combined = 0;
866 for (i = 0; i < 5; ++i) {
867 o_lfsr1 = lfsr1_bits0[lfsr1_hi] ^ lfsr1_bits1[lfsr1_lo];
868 lfsr1_hi = lfsr1_lo>>1;
869 lfsr1_lo = ((lfsr1_lo&1)<<8) ^ o_lfsr1;
870 o_lfsr1 = bit_reverse[o_lfsr1];
872 /*o_lfsr0 = (lfsr0>>7)^(lfsr0>>10)^(lfsr0>>11)^(lfsr0>>19);*/
873 o_lfsr0 = (((((((lfsr0>>8)^lfsr0)>>1)^lfsr0)>>3)^lfsr0)>>7);
874 lfsr0 = (lfsr0>>8)|(o_lfsr0<<24);
876 combined += (o_lfsr0 ^ invert) + o_lfsr1;
877 k[i] = combined & 0xff;
878 combined >>= 8;
881 key[4] = k[4] ^ csstab1[key[4]] ^ key[3];
882 key[3] = k[3] ^ csstab1[key[3]] ^ key[2];
883 key[2] = k[2] ^ csstab1[key[2]] ^ key[1];
884 key[1] = k[1] ^ csstab1[key[1]] ^ key[0];
885 key[0] = k[0] ^ csstab1[key[0]] ^ key[4];
887 key[4] = k[4] ^ csstab1[key[4]] ^ key[3];
888 key[3] = k[3] ^ csstab1[key[3]] ^ key[2];
889 key[2] = k[2] ^ csstab1[key[2]] ^ key[1];
890 key[1] = k[1] ^ csstab1[key[1]] ^ key[0];
891 key[0] = k[0] ^ csstab1[key[0]];
896 * this function decrypts a title key with the specified disk key
898 * tkey: the unobfuscated title key (XORed with BusKey)
899 * dkey: the unobfuscated disk key (XORed with BusKey)
900 * 2048 bytes in length (though only 5 bytes are needed, see below)
902 * use the result returned in tkey with css_descramble
906 static int decrypt_title_key(mpeg3_css_t *css, unsigned char *dkey, unsigned char *tkey)
908 unsigned char test[5], pretkey[5];
909 int i = 0;
911 for(i = 0; mpeg3_playkeys[i]; i++)
913 memcpy(pretkey, dkey + mpeg3_playkeys[i]->offset, 5);
914 title_key(pretkey, mpeg3_playkeys[i]->key, 0);
916 memcpy(test, dkey, 5);
917 title_key(test, pretkey, 0);
919 if(memcmp(test, pretkey, 5) == 0)
920 break;
923 if(!mpeg3_playkeys[i])
925 fprintf(stderr, "mpeg3_decrypttitlekey: Shit - Need key %d\n", i + 1);
926 return 1;
929 title_key(css->title_key, pretkey, 0xff);
931 return 0;
936 * The descrambling core
938 * sec: encrypted sector (2048 bytes)
939 * key: decrypted title key obtained from css_decrypttitlekey
943 #define SALTED(i) (key[i] ^ sec[0x54 - offset + (i)])
945 static void descramble(unsigned char *sec, unsigned char *key, int offset)
947 unsigned int lfsr1_lo, lfsr1_hi, lfsr0, combined;
948 unsigned char o_lfsr0, o_lfsr1;
949 unsigned char *end = sec + 0x800 - offset;
951 if(offset > 0x54)
952 fprintf(stderr, "mpeg3css.c: descramble: offset > 0x54 offset=%x\n", offset);
954 lfsr1_lo = SALTED(0) | 0x100;
955 lfsr1_hi = SALTED(1);
957 lfsr0 = ((SALTED(4) << 17) | (SALTED(3) << 9) | (SALTED(2) << 1)) + 8 - (SALTED(2) & 7);
958 lfsr0 = (bit_reverse[lfsr0 & 0xff] << 24) | (bit_reverse[(lfsr0 >> 8) & 0xff] << 16)
959 | (bit_reverse[(lfsr0 >> 16) & 0xff] << 8) | bit_reverse[(lfsr0 >> 24) & 0xff];
961 sec += 0x80 - offset;
962 combined = 0;
963 while(sec != end)
965 o_lfsr1 = lfsr1_bits0[lfsr1_hi] ^ lfsr1_bits1[lfsr1_lo];
966 lfsr1_hi = lfsr1_lo >> 1;
967 lfsr1_lo = ((lfsr1_lo&1) << 8) ^ o_lfsr1;
968 o_lfsr1 = bit_reverse[o_lfsr1];
970 /*o_lfsr0 = (lfsr0 >> 7) ^ (lfsr0 >> 10) ^ (lfsr0 >> 11) ^ (lfsr0 >> 19);*/
971 o_lfsr0 = (((((((lfsr0 >> 8) ^ lfsr0) >> 1) ^ lfsr0) >> 3) ^ lfsr0) >> 7);
972 lfsr0 = (lfsr0 >> 8) | (o_lfsr0 << 24);
974 combined += o_lfsr0 + (unsigned char)~o_lfsr1;
976 *sec = csstab1[*sec] ^ (combined & 0xff);
977 sec++;
979 combined >>= 8;
981 //printf("descramble\n");
984 /* =============================== Entry Points ================================= */
986 mpeg3_css_t* mpeg3_new_css()
988 mpeg3_css_t *css = calloc(1, sizeof(mpeg3_css_t));
989 css->varient = -1;
990 return css;
993 int mpeg3_delete_css(mpeg3_css_t *css)
995 free(css);
996 return 0;
999 int mpeg3_get_keys(mpeg3_css_t *css, char *path)
1001 int result = 0;
1003 strcpy(css->path, path);
1004 /* Get disk key */
1005 result = validate_path(css, 0);
1006 /* Get title key */
1007 if(!result) result = validate_path(css, 1);
1008 /* Descramble the title key */
1009 if(!result) result = decrypt_title_key(css, css->disk_key, css->title_key);
1011 return css->encrypted ? result : 0;
1014 /* sector is the full 2048 byte sector */
1015 int mpeg3_decrypt_packet(mpeg3_css_t *css, unsigned char *sector, int offset)
1017 //printf("mpeg3_decrypt_packet %d\n", css->encrypted);
1018 if(!css->encrypted) return 0; /* Not encrypted */
1019 descramble(sector, css->title_key, offset);
1020 return 0;
1023 #else // HAVE_CSS
1025 #include "mpeg3css_fake.c"
1027 #endif