Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
c5695896
Commit
c5695896
authored
May 05, 2004
by
Jon Lech Johansen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* drms.c: DRMS v2 support. Thanks to sam for cleaning and breaking up
DoExtShuffle into smaller functions.
parent
68d75ffc
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
831 additions
and
4 deletions
+831
-4
modules/demux/mp4/drms.c
modules/demux/mp4/drms.c
+831
-4
No files found.
modules/demux/mp4/drms.c
View file @
c5695896
...
...
@@ -2,7 +2,7 @@
* drms.c: DRMS
*****************************************************************************
* Copyright (C) 2004 VideoLAN
* $Id
: drms.c,v 1.13 2004/02/17 13:13:31 gbazin Exp
$
* $Id$
*
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
* Sam Hocevar <sam@zoy.org>
...
...
@@ -102,10 +102,25 @@ struct md5_s
*****************************************************************************/
struct
shuffle_s
{
uint32_t
i_version
;
uint32_t
p_commands
[
20
];
uint32_t
p_bordel
[
16
];
};
/*****************************************************************************
* shuffle_ext_s: extended shuffle structure
*****************************************************************************
* This structure stores the static information needed to shuffle data using
* a custom algorithm.
*****************************************************************************/
struct
shuffle_ext_s
{
uint32_t
*
p_bordel
;
uint32_t
i_cmd
,
i_jc
,
i_tmp
;
};
#define SWAP( a, b ) { (a) ^= (b); (b) ^= (a); (a) ^= (b); }
/*****************************************************************************
* drms_s: DRMS structure
*****************************************************************************
...
...
@@ -135,9 +150,20 @@ static void AddMD5 ( struct md5_s *, const uint8_t *, uint32_t );
static
void
EndMD5
(
struct
md5_s
*
);
static
void
Digest
(
struct
md5_s
*
,
uint32_t
*
);
static
void
InitShuffle
(
struct
shuffle_s
*
,
uint32_t
*
);
static
void
InitShuffle
(
struct
shuffle_s
*
,
uint32_t
*
,
uint32_t
);
static
void
DoShuffle
(
struct
shuffle_s
*
,
uint32_t
*
,
uint32_t
);
static
uint32_t
FirstPass
(
uint32_t
*
);
static
void
SecondPass
(
struct
shuffle_ext_s
*
);
static
uint32_t
ThirdPass
(
uint32_t
*
);
static
void
FourthPass
(
uint32_t
*
,
uint32_t
);
static
void
FifthPass
(
uint32_t
*
);
static
void
BigShuffle1
(
struct
shuffle_ext_s
*
);
static
void
BigShuffle2
(
struct
shuffle_ext_s
*
);
static
void
TinyShuffle1
(
uint32_t
*
);
static
void
TinyShuffle2
(
uint32_t
*
);
static
void
DoExtShuffle
(
uint32_t
*
);
static
int
GetSystemKey
(
uint32_t
*
,
vlc_bool_t
);
static
int
WriteUserKey
(
void
*
,
uint32_t
*
);
static
int
ReadUserKey
(
void
*
,
uint32_t
*
);
...
...
@@ -647,13 +673,16 @@ static void Digest( struct md5_s *p_md5, uint32_t *p_input )
* This function initialises tables in the p_shuffle structure that will be
* used later by DoShuffle. The only external parameter is p_sys_key.
*****************************************************************************/
static
void
InitShuffle
(
struct
shuffle_s
*
p_shuffle
,
uint32_t
*
p_sys_key
)
static
void
InitShuffle
(
struct
shuffle_s
*
p_shuffle
,
uint32_t
*
p_sys_key
,
uint32_t
i_version
)
{
char
p_secret1
[]
=
"Tv!*"
;
static
char
const
p_secret2
[]
=
"v8rhvsaAvOKMFfUH%798=[;."
"f8677680a634ba87fnOIf)(*"
;
unsigned
int
i
;
p_shuffle
->
i_version
=
i_version
;
/* Fill p_commands using the key and a secret seed */
for
(
i
=
0
;
i
<
20
;
i
++
)
{
...
...
@@ -696,6 +725,34 @@ static void DoShuffle( struct shuffle_s *p_shuffle,
uint32_t
*
p_bordel
=
p_shuffle
->
p_bordel
;
unsigned
int
i
;
static
uint32_t
i_secret
=
0
;
static
uint32_t
p_secret1
[]
=
{
0xAAAAAAAA
,
0x01757700
,
0x00554580
,
0x01724500
,
0x00424580
,
0x01427700
,
0x00000080
,
0xC1D59D01
,
0x80144981
,
0x815C8901
,
0x80544981
,
0x81D45D01
,
0x00000080
,
0x81A3BB03
,
0x00A2AA82
,
0x01A3BB03
,
0x0022A282
,
0x813BA202
,
0x00000080
,
0x6D575737
,
0x4A5275A5
,
0x6D525725
,
0x4A5254A5
,
0x6B725437
,
0x00000080
,
0xD5DDB938
,
0x5455A092
,
0x5D95A013
,
0x4415A192
,
0xC5DD393A
,
0x00000080
,
0x55555555
};
static
char
p_secret2
[]
=
"pbclevtug (p) Nccyr Pbzchgre, Vap. Nyy Evtugf Erfreirq."
;
if
(
i_secret
==
0
)
{
REVERSE
(
p_secret1
,
sizeof
(
p_secret1
)
/
sizeof
(
p_secret1
[
0
])
);
for
(
;
p_secret2
[
i_secret
]
!=
'\0'
;
i_secret
++
)
{
#define ROT13(c) (((c)>='A'&&(c)<='Z')?(((c)-'A'+13)%26)+'A':\
((c)>='a'&&(c)<='z')?(((c)-'a'+13)%26)+'a':c)
p_secret2
[
i_secret
]
=
ROT13
(
p_secret2
[
i_secret
]);
}
i_secret
++
;
/* include zero terminator */
}
/* Using the MD5 hash of a memory block is probably not one-way enough
* for the iTunes people. This function randomises p_bordel depending on
* the values in p_commands to make things even more messy in p_bordel. */
...
...
@@ -729,6 +786,11 @@ static void DoShuffle( struct shuffle_s *p_shuffle,
}
}
if
(
p_shuffle
->
i_version
==
0x01000300
)
{
DoExtShuffle
(
p_bordel
);
}
/* Convert our newly randomised p_bordel to big endianness and take
* its MD5 hash. */
InitMD5
(
&
md5
);
...
...
@@ -737,6 +799,11 @@ static void DoShuffle( struct shuffle_s *p_shuffle,
p_big_bordel
[
i
]
=
U32_AT
(
p_bordel
+
i
);
}
AddMD5
(
&
md5
,
(
uint8_t
*
)
p_big_bordel
,
64
);
if
(
p_shuffle
->
i_version
==
0x01000300
)
{
AddMD5
(
&
md5
,
(
uint8_t
*
)
p_secret1
,
sizeof
(
p_secret1
)
);
AddMD5
(
&
md5
,
(
uint8_t
*
)
p_secret2
,
i_secret
);
}
EndMD5
(
&
md5
);
/* XOR our buffer with the computed checksum */
...
...
@@ -746,6 +813,766 @@ static void DoShuffle( struct shuffle_s *p_shuffle,
}
}
/*****************************************************************************
* DoExtShuffle: extended shuffle
*****************************************************************************
* This is even uglier.
*****************************************************************************/
static
void
DoExtShuffle
(
uint32_t
*
p_bordel
)
{
uint32_t
i_ret
;
struct
shuffle_ext_s
exs
;
exs
.
p_bordel
=
p_bordel
;
exs
.
i_tmp
=
FirstPass
(
p_bordel
);
SecondPass
(
&
exs
);
i_ret
=
ThirdPass
(
p_bordel
);
FourthPass
(
p_bordel
,
i_ret
);
FifthPass
(
p_bordel
);
}
static
uint32_t
FirstPass
(
uint32_t
*
p_bordel
)
{
uint32_t
i
,
j
;
uint32_t
i_cmd
,
i_ret
;
i_ret
=
5
;
i_cmd
=
(
p_bordel
[
5
]
+
10
)
>>
2
;
if
(
p_bordel
[
5
]
>
0x7D0
)
{
i_cmd
-=
0x305
;
}
switch
(
i_cmd
&
3
)
{
case
0
:
p_bordel
[
5
]
+=
5
;
break
;
case
1
:
p_bordel
[
4
]
-=
1
;
break
;
case
2
:
if
(
p_bordel
[
4
]
&
5
)
{
p_bordel
[
1
]
^=
0x4D
;
}
/* no break */
case
3
:
p_bordel
[
12
]
+=
5
;
break
;
}
for
(
;
;
)
{
for
(
;
;
)
{
p_bordel
[
1
]
+=
0x10000000
;
p_bordel
[
3
]
+=
0x12777
;
if
(
(
p_bordel
[
10
]
&
1
)
&&
i_ret
)
{
i_ret
--
;
p_bordel
[
1
]
-=
p_bordel
[
2
];
p_bordel
[
11
]
+=
p_bordel
[
12
];
break
;
}
if
(
(
p_bordel
[
1
]
+
p_bordel
[
2
])
>=
0x7D0
)
{
i_cmd
=
((
p_bordel
[
3
]
^
0x567F
)
>>
2
)
&
7
;
switch
(
i_cmd
)
{
case
0
:
for
(
i
=
0
;
i
<
3
;
i
++
)
{
if
(
p_bordel
[
i
+
10
]
>
0x4E20
)
{
p_bordel
[
i
+
1
]
+=
p_bordel
[
i
+
2
];
}
}
break
;
case
4
:
p_bordel
[
1
]
-=
p_bordel
[
2
];
/* no break */
case
3
:
p_bordel
[
11
]
+=
p_bordel
[
12
];
break
;
case
6
:
p_bordel
[
3
]
^=
p_bordel
[
4
];
/* no break */
case
8
:
p_bordel
[
13
]
&=
p_bordel
[
14
];
/* no break */
case
1
:
p_bordel
[
0
]
|=
p_bordel
[
1
];
if
(
i_ret
)
{
return
i_ret
;
}
break
;
}
break
;
}
}
for
(
i
=
0
,
i_cmd
=
0
;
i
<
16
;
i
++
)
{
if
(
p_bordel
[
i
]
<
p_bordel
[
i_cmd
]
)
{
i_cmd
=
i
;
}
}
if
(
i_ret
&&
i_cmd
!=
5
)
{
i_ret
--
;
}
else
{
if
(
i_cmd
==
5
)
{
p_bordel
[
8
]
&=
p_bordel
[
6
]
>>
1
;
p_bordel
[
3
]
<<=
1
;
}
for
(
i
=
0
;
i
<
3
;
i
++
)
{
p_bordel
[
11
]
+=
1
;
if
(
p_bordel
[
11
]
&
5
)
{
p_bordel
[
8
]
+=
p_bordel
[
9
];
}
else
if
(
i_ret
)
{
i_ret
--
;
i_cmd
=
3
;
goto
break2
;
}
}
i_cmd
=
(
p_bordel
[
15
]
+
0x93
)
>>
3
;
if
(
p_bordel
[
15
]
&
0x100
)
{
i_cmd
^=
0xDEAD
;
}
}
switch
(
i_cmd
&
3
)
{
case
0
:
while
(
p_bordel
[
11
]
&
1
)
{
p_bordel
[
11
]
>>=
1
;
p_bordel
[
12
]
+=
1
;
}
/* no break */
case
2
:
p_bordel
[
14
]
-=
0x19FE
;
break
;
case
3
:
if
(
i_ret
)
{
i_ret
--
;
p_bordel
[
5
]
+=
5
;
continue
;
}
break
;
}
i_cmd
=
((
p_bordel
[
3
]
+
p_bordel
[
4
]
+
10
)
>>
1
)
-
p_bordel
[
4
];
break
;
}
break2:
switch
(
i_cmd
&
3
)
{
case
0
:
p_bordel
[
14
]
>>=
1
;
break
;
case
1
:
p_bordel
[
5
]
<<=
2
;
break
;
case
2
:
p_bordel
[
12
]
|=
5
;
break
;
case
3
:
p_bordel
[
15
]
&=
0x55
;
if
(
i_ret
)
{
p_bordel
[
2
]
&=
0xB62FC
;
return
i_ret
;
}
break
;
}
for
(
i
=
0
,
j
=
0
;
i
<
16
;
i
++
)
{
if
(
(
p_bordel
[
i
]
&
0x777
)
>
(
p_bordel
[
j
]
&
0x777
)
)
{
j
=
i
;
}
}
if
(
j
>
5
)
{
for
(
;
j
<
15
;
j
++
)
{
p_bordel
[
j
]
+=
p_bordel
[
j
+
1
];
}
}
else
{
p_bordel
[
2
]
&=
0xB62FC
;
}
return
i_ret
;
}
static
void
SecondPass
(
struct
shuffle_ext_s
*
p_exs
)
{
uint32_t
i
;
p_exs
->
i_cmd
=
p_exs
->
p_bordel
[
6
]
+
0x194B
;
if
(
p_exs
->
p_bordel
[
6
]
>
0x2710
)
{
p_exs
->
i_cmd
>>=
1
;
}
switch
(
p_exs
->
i_cmd
&
3
)
{
case
1
:
p_exs
->
p_bordel
[
3
]
+=
0x19FE
;
break
;
case
2
:
p_exs
->
p_bordel
[
7
]
-=
p_exs
->
p_bordel
[
3
]
>>
2
;
/* no break */
case
0
:
p_exs
->
p_bordel
[
5
]
^=
0x248A
;
break
;
}
p_exs
->
i_jc
=
5
;
for
(
i
=
0
,
p_exs
->
i_cmd
=
0
;
i
<
16
;
i
++
)
{
if
(
p_exs
->
p_bordel
[
i
]
>
p_exs
->
p_bordel
[
p_exs
->
i_cmd
]
)
{
p_exs
->
i_cmd
=
i
;
}
}
switch
(
p_exs
->
i_cmd
)
{
case
0
:
if
(
p_exs
->
p_bordel
[
1
]
<
p_exs
->
p_bordel
[
8
]
)
{
p_exs
->
p_bordel
[
5
]
+=
1
;
}
break
;
case
4
:
if
(
(
p_exs
->
p_bordel
[
9
]
&
0x7777
)
==
0x3333
)
{
p_exs
->
p_bordel
[
5
]
-=
1
;
}
else
{
p_exs
->
i_jc
--
;
if
(
p_exs
->
p_bordel
[
1
]
<
p_exs
->
p_bordel
[
8
]
)
{
p_exs
->
p_bordel
[
5
]
+=
1
;
}
break
;
}
/* no break */
case
7
:
p_exs
->
p_bordel
[
2
]
-=
1
;
p_exs
->
p_bordel
[
1
]
-=
p_exs
->
p_bordel
[
5
];
TinyShuffle1
(
p_exs
->
p_bordel
);
return
;
case
10
:
p_exs
->
p_bordel
[
4
]
-=
1
;
p_exs
->
p_bordel
[
5
]
+=
1
;
p_exs
->
p_bordel
[
6
]
-=
1
;
p_exs
->
p_bordel
[
7
]
+=
1
;
break
;
default:
p_exs
->
p_bordel
[
15
]
^=
0x18547EFF
;
break
;
}
BigShuffle1
(
p_exs
);
}
static
void
BigShuffle1
(
struct
shuffle_ext_s
*
p_exs
)
{
uint32_t
i
,
j
;
for
(
i
=
0
;
i
<
3
;
i
++
)
{
p_exs
->
i_cmd
=
p_exs
->
p_bordel
[
12
]
+
p_exs
->
p_bordel
[
13
]
+
p_exs
->
p_bordel
[
6
];
p_exs
->
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
p_exs
->
i_cmd
*
0x0CCCCCCCD
)
>>
32
))
>>
2
)
*
5
;
if
(
p_exs
->
i_cmd
>
4
)
{
break
;
}
switch
(
p_exs
->
i_cmd
)
{
case
0
:
p_exs
->
p_bordel
[
12
]
-=
1
;
/* no break */
case
1
:
p_exs
->
p_bordel
[
12
]
-=
1
;
p_exs
->
p_bordel
[
13
]
+=
1
;
break
;
case
2
:
p_exs
->
p_bordel
[
13
]
+=
4
;
/* no break */
case
3
:
p_exs
->
p_bordel
[
12
]
-=
1
;
break
;
case
4
:
if
(
p_exs
->
i_jc
)
{
p_exs
->
i_jc
--
;
p_exs
->
p_bordel
[
5
]
+=
1
;
p_exs
->
p_bordel
[
6
]
-=
1
;
p_exs
->
p_bordel
[
7
]
+=
1
;
BigShuffle1
(
p_exs
);
return
;
}
break
;
}
}
for
(
i
=
0
,
j
=
0
;
i
<
16
;
i
++
)
{
if
(
p_exs
->
p_bordel
[
i
]
<
p_exs
->
p_bordel
[
j
]
)
{
j
=
i
;
}
}
if
(
(
p_exs
->
p_bordel
[
j
]
%
(
j
+
1
))
>
10
)
{
p_exs
->
p_bordel
[
1
]
-=
1
;
p_exs
->
p_bordel
[
2
]
+=
0x13
;
p_exs
->
p_bordel
[
12
]
+=
1
;
}
BigShuffle2
(
p_exs
);
}
static
void
BigShuffle2
(
struct
shuffle_ext_s
*
p_exs
)
{
uint32_t
i
;
p_exs
->
p_bordel
[
2
]
&=
0x7F3F
;
for
(
i
=
0
;
i
<
5
;
i
++
)
{
p_exs
->
i_cmd
=
(
p_exs
->
p_bordel
[
2
]
+
0xA
)
+
i
;
p_exs
->
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
p_exs
->
i_cmd
*
0x0CCCCCCCD
)
>>
32
))
>>
2
)
*
5
;
if
(
p_exs
->
i_cmd
>
4
)
{
continue
;
}
switch
(
p_exs
->
i_cmd
)
{
case
0
:
p_exs
->
p_bordel
[
12
]
&=
p_exs
->
p_bordel
[
2
];
/* no break */
case
1
:
p_exs
->
p_bordel
[
3
]
^=
p_exs
->
p_bordel
[
15
];
break
;
case
2
:
p_exs
->
p_bordel
[
15
]
+=
0x576
;
/* no break */
case
3
:
p_exs
->
p_bordel
[
7
]
-=
0x2D
;
/* no break */
case
4
:
p_exs
->
p_bordel
[
1
]
<<=
1
;
break
;
}
}
p_exs
->
i_cmd
=
(
p_exs
->
p_bordel
[
2
]
*
2
)
+
15
;
p_exs
->
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
p_exs
->
i_cmd
*
0x0CCCCCCCD
)
>>
32
))
>>
2
)
*
5
;
switch
(
p_exs
->
i_cmd
)
{
case
0
:
if
(
(
p_exs
->
p_bordel
[
3
]
+
p_exs
->
i_tmp
)
<=
(
p_exs
->
p_bordel
[
1
]
+
p_exs
->
p_bordel
[
15
]
)
)
{
p_exs
->
p_bordel
[
3
]
+=
1
;
}
break
;
case
3
:
p_exs
->
p_bordel
[
5
]
>>=
2
;
break
;
case
4
:
p_exs
->
p_bordel
[
10
]
-=
0x13
;
break
;
}
p_exs
->
i_cmd
=
((
p_exs
->
p_bordel
[
2
]
*
2
)
+
10
)
>>
1
;
if
(
p_exs
->
p_bordel
[
2
]
&
1
)
{
if
(
p_exs
->
i_jc
)
{
p_exs
->
i_jc
--
;
p_exs
->
p_bordel
[
2
]
+=
0x13
;
p_exs
->
p_bordel
[
12
]
+=
1
;
BigShuffle2
(
p_exs
);
return
;
}
}
p_exs
->
i_cmd
-=
p_exs
->
p_bordel
[
2
];
p_exs
->
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
p_exs
->
i_cmd
*
0x0CCCCCCCD
)
>>
32
))
>>
3
)
*
10
;
switch
(
p_exs
->
i_cmd
)
{
case
0
:
for
(
i
=
0
;
i
<
5
;
i
++
)
{
if
(
(
p_exs
->
p_bordel
[
1
]
&
p_exs
->
p_bordel
[
2
]
)
>
(
p_exs
->
p_bordel
[
7
]
&
p_exs
->
p_bordel
[
12
]
)
)
{
p_exs
->
p_bordel
[
2
]
+=
1
;
p_exs
->
p_bordel
[
7
]
^=
p_exs
->
p_bordel
[
2
];
}
}
case
1
:
p_exs
->
p_bordel
[
3
]
-=
1
;
p_exs
->
p_bordel
[
4
]
|=
0x400000
;
break
;
case
2
:
if
(
p_exs
->
p_bordel
[
13
]
>=
p_exs
->
p_bordel
[
3
]
)
{
if
(
p_exs
->
i_jc
)
{
p_exs
->
i_jc
--
;
p_exs
->
p_bordel
[
5
]
+=
1
;
p_exs
->
p_bordel
[
6
]
-=
1
;
p_exs
->
p_bordel
[
7
]
+=
1
;
BigShuffle1
(
p_exs
);
}
return
;
}
else
{
p_exs
->
p_bordel
[
5
]
+=
3
;
}
break
;
case
3
:
p_exs
->
p_bordel
[
1
]
^=
(
p_exs
->
p_bordel
[
5
]
+
p_exs
->
p_bordel
[
15
]);
break
;
case
4
:
p_exs
->
p_bordel
[
14
]
+=
1
;
break
;
case
5
:
p_exs
->
p_bordel
[
2
]
&=
0x10076000
;
break
;
case
6
:
p_exs
->
p_bordel
[
1
]
-=
p_exs
->
p_bordel
[
5
];
/* no break */
case
7
:
TinyShuffle1
(
p_exs
->
p_bordel
);
break
;
case
8
:
p_exs
->
p_bordel
[
7
]
^=
((
p_exs
->
p_bordel
[
1
]
+
p_exs
->
p_bordel
[
5
])
-
p_exs
->
p_bordel
[
8
]);
break
;
case
9
:
if
(
(
p_exs
->
p_bordel
[
1
]
^
p_exs
->
p_bordel
[
10
])
>
0x6000
)
{
p_exs
->
p_bordel
[
11
]
+=
1
;
}
break
;
}
}
static
uint32_t
ThirdPass
(
uint32_t
*
p_bordel
)
{
uint32_t
i_cmd
,
i_ret
=
5
;
i_cmd
=
((
p_bordel
[
7
]
+
p_bordel
[
14
]
+
10
)
>>
1
)
-
p_bordel
[
14
];
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
i_cmd
*
0x0CCCCCCCD
)
>>
32
))
>>
3
)
*
10
;
switch
(
i_cmd
)
{
case
0
:
p_bordel
[
1
]
<<=
1
;
p_bordel
[
2
]
<<=
2
;
p_bordel
[
3
]
<<=
3
;
break
;
case
6
:
p_bordel
[
i_cmd
+
3
]
&=
0x5EDE36B
;
/* no break */
case
2
:
while
(
i_cmd
)
{
i_cmd
-=
1
;
p_bordel
[
i_cmd
]
+=
p_bordel
[
i_cmd
+
3
];
}
i_ret
--
;
TinyShuffle2
(
p_bordel
);
return
i_ret
;
case
3
:
if
(
(
p_bordel
[
11
]
&
p_bordel
[
2
])
>
0x211B
)
{
p_bordel
[
6
]
+=
1
;
}
break
;
case
4
:
p_bordel
[
7
]
+=
1
;
/* no break */
case
5
:
p_bordel
[
9
]
^=
p_bordel
[
2
];
break
;
case
7
:
p_bordel
[
2
]
^=
(
p_bordel
[
1
]
&
p_bordel
[
13
]);
break
;
case
8
:
p_bordel
[
0
]
-=
p_bordel
[
11
]
&
p_bordel
[
15
];
i_ret
--
;
return
i_ret
;
case
9
:
p_bordel
[
6
]
>>=
(
p_bordel
[
14
]
&
3
);
break
;
}
SWAP
(
p_bordel
[
0
],
p_bordel
[
10
]
);
TinyShuffle2
(
p_bordel
);
return
i_ret
;
}
static
void
FourthPass
(
uint32_t
*
p_bordel
,
uint32_t
i_jc
)
{
uint32_t
i
,
j
;
uint32_t
i_cmd
;
i
=
(((
p_bordel
[
9
]
+
p_bordel
[
15
]
+
12
)
>>
2
)
-
p_bordel
[
4
])
&
7
;
while
(
i
--
)
{
SWAP
(
p_bordel
[
i
],
p_bordel
[
i
+
3
]
);
}
SWAP
(
p_bordel
[
10
],
p_bordel
[
1
]
);
i_cmd
=
p_bordel
[
5
];
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
i_cmd
*
0x0CCCCCCCD
)
>>
32
))
>>
2
)
*
5
;
switch
(
i_cmd
)
{
case
0
:
p_bordel
[
0
]
+=
1
;
break
;
case
2
:
p_bordel
[
11
]
^=
(
p_bordel
[
3
]
+
p_bordel
[
6
]
+
p_bordel
[
8
]);
break
;
case
3
:
for
(
i
=
4
;
i
<
15
;
i
++
)
{
if
(
p_bordel
[
i
]
&
5
)
{
break
;
}
SWAP
(
p_bordel
[
i
],
p_bordel
[
15
-
i
]
);
}
break
;
case
4
:
if
(
i_jc
)
{
p_bordel
[
12
]
-=
1
;
p_bordel
[
13
]
+=
1
;
p_bordel
[
2
]
-=
0x64
;
p_bordel
[
3
]
+=
0x64
;
return
;
}
break
;
}
for
(
i
=
0
,
j
=
0
;
i
<
16
;
i
++
)
{
if
(
p_bordel
[
i
]
>
p_bordel
[
j
]
)
{
j
=
i
;
}
}
i_cmd
=
p_bordel
[
j
];
i_cmd
-=
(((
uint32_t
)(((
uint64_t
)
i_cmd
*
0x51EB851F
)
>>
32
))
>>
5
)
*
0x64
;
switch
(
i_cmd
)
{
case
0x0
:
SWAP
(
p_bordel
[
j
],
p_bordel
[
0
]
);
break
;
case
0x8
:
p_bordel
[
1
]
>>=
1
;
p_bordel
[
2
]
<<=
1
;
p_bordel
[
14
]
>>=
3
;
p_bordel
[
15
]
<<=
4
;
break
;
case
0x39
:
p_bordel
[
j
]
+=
p_bordel
[
13
];
break
;
case
0x4c
:
if
(
i_jc
)
{
p_bordel
[
1
]
+=
0x20E
;
p_bordel
[
5
]
+=
0x223D
;
p_bordel
[
13
]
-=
0x576
;
p_bordel
[
15
]
+=
0x576
;
}
break
;
case
0x5b
:
p_bordel
[
2
]
-=
0x64
;
p_bordel
[
3
]
+=
0x64
;
p_bordel
[
12
]
-=
1
;
p_bordel
[
13
]
+=
1
;
break
;
case
0x63
:
p_bordel
[
0
]
+=
1
;
p_bordel
[
j
]
+=
p_bordel
[
13
];
break
;
}
}
static
void
FifthPass
(
uint32_t
*
p_bordel
)
{
uint32_t
i
;
uint32_t
i_cmd
;
i
=
(
p_bordel
[
0
]
&
p_bordel
[
6
])
&
0xF
;
i_cmd
=
p_bordel
[
i
];
i_cmd
-=
((((
uint32_t
)(((
uint64_t
)
i_cmd
*
0x10624DD3
)
>>
32
))
>>
6
)
*
0x3E8
);
switch
(
i_cmd
)
{
case
0x7
:
if
(
(
p_bordel
[
i
]
&
0x777
)
>
(
p_bordel
[
7
]
&
0x5555
)
)
{
p_bordel
[
i
]
^=
p_bordel
[
5
]
&
p_bordel
[
3
];
}
break
;
case
0x13
:
p_bordel
[
15
]
&=
0x5555
;
break
;
case
0x5d
:
p_bordel
[
i
]
^=
p_bordel
[
15
];
break
;
case
0x64
:
SWAP
(
p_bordel
[
0
],
p_bordel
[
1
]
);
SWAP
(
p_bordel
[
1
],
p_bordel
[
7
]
);
SWAP
(
p_bordel
[
4
],
p_bordel
[
9
]
);
SWAP
(
p_bordel
[
8
],
p_bordel
[
5
]
);
SWAP
(
p_bordel
[
6
],
p_bordel
[
1
]
);
SWAP
(
p_bordel
[
3
],
p_bordel
[
0
]
);
SWAP
(
p_bordel
[
13
],
p_bordel
[
14
]
);
break
;
case
0x149
:
p_bordel
[
i
]
+=
p_bordel
[
1
]
^
0x80080011
;
p_bordel
[
i
]
+=
p_bordel
[
2
]
^
0xBEEFDEAD
;
p_bordel
[
i
]
+=
p_bordel
[
3
]
^
0x8765F444
;
p_bordel
[
i
]
+=
p_bordel
[
4
]
^
0x78145326
;
break
;
case
0x237
:
p_bordel
[
12
]
-=
p_bordel
[
i
];
p_bordel
[
13
]
+=
p_bordel
[
i
];
break
;
case
0x264
:
p_bordel
[
i
]
+=
p_bordel
[
1
];
p_bordel
[
i
]
-=
p_bordel
[
7
];
p_bordel
[
i
]
-=
p_bordel
[
8
];
p_bordel
[
i
]
+=
p_bordel
[
9
];
p_bordel
[
i
]
+=
p_bordel
[
13
];
break
;
case
0x2f2
:
i
=
__MIN
(
i
,
12
);
p_bordel
[
i
+
1
]
>>=
1
;
p_bordel
[
i
+
2
]
<<=
4
;
p_bordel
[
i
+
3
]
>>=
3
;
break
;
case
0x309
:
p_bordel
[
1
]
+=
0x20E
;
p_bordel
[
5
]
+=
0x223D
;
p_bordel
[
13
]
-=
0x576
;
p_bordel
[
15
]
+=
0x576
;
break
;
case
0x3d5
:
if
(
(
p_bordel
[
i
]
^
0x8765F441
)
<
0x2710
)
{
SWAP
(
p_bordel
[
0
],
p_bordel
[
1
]
);
}
else
{
SWAP
(
p_bordel
[
1
],
p_bordel
[
11
]
);
}
break
;
}
}
static
void
TinyShuffle1
(
uint32_t
*
p_bordel
)
{
uint32_t
i
;
for
(
i
=
0
;
i
<
3
;
i
++
)
{
switch
(
p_bordel
[
1
]
&
3
)
{
case
0
:
p_bordel
[
1
]
+=
1
;
/* no break */
case
1
:
p_bordel
[
3
]
-=
8
;
break
;
case
2
:
p_bordel
[
13
]
&=
0xFEFEFEF7
;
break
;
case
3
:
p_bordel
[
8
]
|=
0x80080011
;
break
;
}
}
}
static
void
TinyShuffle2
(
uint32_t
*
p_bordel
)
{
uint32_t
i
;
for
(
i
=
0
;
i
<
8
;
i
++
)
{
if
(
p_bordel
[
3
]
&
0x7514
)
{
SWAP
(
p_bordel
[
i
],
p_bordel
[
i
+
5
]
);
}
else
{
SWAP
(
p_bordel
[
i
],
p_bordel
[
i
+
7
]
);
}
}
}
/*****************************************************************************
* GetSystemKey: get the system key
*****************************************************************************
...
...
@@ -919,7 +1746,7 @@ static int GetUserKey( void *_p_drms, uint32_t *p_user_key )
/* Decrypt and shuffle our data at the same time */
InitAES
(
&
aes
,
p_sys_key
);
REVERSE
(
p_sys_key
,
4
);
InitShuffle
(
&
shuffle
,
p_sys_key
);
InitShuffle
(
&
shuffle
,
p_sys_key
,
p_sci_data
[
0
]
);
memcpy
(
p_sci_key
,
p_secret
,
16
);
REVERSE
(
p_sci_key
,
4
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment