SlideShare a Scribd company logo
let’s play with crypto! 
Ange Albertini 
MetaRheinMainConstructionDays 
MRMCD 
5-7 september 2014 
HS Darmstadt 
www.mrmcd.net 2014/09/05
Ange Albertini 
reverse engineering & 
visual documentations 
@angealbertini 
ange@corkami.com 
http://www.corkami.com
an encrypted file is 
not always encrypted
encrypt(file) 
an encrypted file is 
not always encrypted 
random
Let’s take an example: this is a JPEG picture...
AES( ) 
...if you encrypt it with AES...
… you get this PNG picture...
3DES( ) 
...and if you decrypt it with Triple DES...
...you get a PDF document.
Don’t worry! 
I’ll keep it simple...
...because crypto is (too) hard!
HORROR 
And this is my usual reaction...
...but I can still have fun with it...
PNG 
TrueCrypt 
Crypto 
...so let’s play together !
AES 
Advanced Encryption Standard
1 block (16 bytes)
1 block (16 bytes) 
+ 
1 key (16 bytes)* 
* in the case of AES-128, 
so from now on, we’ll say AES for AES-128.
1 block (16 bytes) 
+ 
1 key (16 bytes) 
1 block (16 bytes)
a block of text. 
+ 
MySecretKey12345 
┐◄n╩i▐☼←∞└╞∙iû╨► 
(BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
a block of text. 
+ 
MySecretKey12346 
gO┼╗ÑëΩcë ▼LÇk╨î 
(67 4F C5 BB A5 89 EA 63 89 20 1F 4C 80 6B D0 8C)
a block of text! 
+ 
MySecretKey12345 
wε╩▬▄y&↕ú@αùαφ♣O 
(77 EE CA 16 DC 79 26 12 A3 40 E0 97 E0 ED 05 4F)
Any change 
in the key or input block 
gives a completely 
different output
we can’t 
control the output 
the differences are unpredictable
the opposite operation
a block of text. 
+ 
MySecretKey12345 
encryption 
┐◄n╩i▐☼←∞└╞∙iû╨► 
(BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
a block of text. 
decryption 
MySecretKey12345 
+ 
┐◄n╩i▐☼←∞└╞∙iû╨► 
(BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
π╔6I►♣♫Σ♣╝╤→√çφ╡ 
(E3 C9 36 49 10 05 0E E4 05 BC D1 1A FB 87 ED B5) 
decryption 
MySecretKey12346 
+ 
┐◄n╩i▐☼←∞└╞∙iû╨► 
(BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
outwith the encryption key, 
we can restore 
the original block
without the encryption key, 
we can’t do anything 
with the encrypted block
“plaintext” and “crypted” 
are just names 
encryption ⇔ decryption 
are just inverse functions
a block of text. 
+ 
MySecretKey12345 
encryption 
┐◄n╩i▐☼←∞└╞∙iû╨► 
(BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
a block of text. 
+ 
MySecretKey12345 
decryption 
ä/ë-╦7 ↓h│☻⌂μ[←Ñ 
(84 2F 89 2D CB 37 00 19 68 B3 02 7F E6 5B 1B A5)
a block of text. 
encryption 
MySecretKey12345 
+ 
ä/ë-╦7 ↓h│☻⌂μ[←Ñ 
(84 2F 89 2D CB 37 00 19 68 B3 02 7F E6 5B 1B A5)
we can decrypt plaintext 
we recover the original block via encryption 
⇒ we can control encryption output
Recap 
● AES encrypts a block 
○ we don’t control the output 
● an encrypted block can be restored 
○ with the encryption key 
● encryption ⇔ decryption are just inverse functions 
○ we can decrypt plaintext 
○ we can recover the original block via encryption 
● we can’t control both input and output 
○ one, or the other
Now, let’s talk about...
This is a cow. This is how a users see it.
This is how an expert sees a cow. 
It’s still the same cow, but it has some internal structure.
Let’s work with a simplified structure of beef chunks.
If our cow swallows a microSD, it’s still a valid cow! 
Even if it contains foreign data, that is tolerated by the system.
Now, let’s look at the Portable Network Graphics format.
Chunk 
● The format is made of variable-sized pieces 
○ critical or ancillary 
● Common high-level structure 
○ independent of the content and its interpretation 
⇒ Store proprietary information while 
⇒ guaranteeing a minimal compatibility
https://www.google.com/images/srpr/logo11w.png 
SHA-1 349841408d1aa1f5a8892686fbdf54777afc0b2c 
Let’s take a real example, that you may have seen before.
A tool for computer butchers. 
(we’ll use it from now on) (’hachoir’ = meatgrinder)
The Google logo, viewed in Hachoir: 
a signature, then a sequence of chunks.
x89 P N G r n ^Z n 
Compulsory signature at offset 0 
● identify the file type 
● identify transfer errors 
○ x89 : non ASCII (ASCII = [0 - 128]) 
○ rn then n : different end of line standards 
○ ^Z (x1A) : “End Of File”
Chunk 
● Common structure: 
a. size, on 4 bytes 
b. type, made of 4 letters 
■ 1st letter: lowercase ⇒ ancillary chunk 
c. data 
d. checksum 
■ CRC32(type + data) 
● We can add custom chunks
IHDR chunk: containing image information
IDAT chunk (compressed): pixels values
IDAT after decompression 
(FF FF FF 00 = black + 100% transparent)
IEND chunk: End of File (‘s structure)
What comes after IEND is ignored by PNG tools. 
(the image is complete)
Recap 
Structure: 
1. Signature at offset 0 
2. Chunks sequence 
a. IHDR header 
b. IDAT data 
c. IEND end
“I know how 
Google works!” 
Now, you can impress your friends!
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
+ 
MySecretKey12345 
:¼N?â?pzILá+?ìgU 
(3A AC 4E 10 83 03 70 7A 49 4C A0 DA 0B 8D 67 55) 
Encryption breaks the signature.
logo11w.png: PNG image data, 538 x 190, 8-bit/color RGBA, non-interlaced 
+ 
MySecretKey12345 
crypted.png: ISO-8859 text, with no line terminators 
Without a signature, the encrypted file is invalid.
If we encrypt a PNG, 
we don’t get a PNG 
the signature is broken and the structure too 
(a priori)
How can we encrypt 
oogle into uc?k 
duckdu 
ckgo
How can we control 
input and output?
AES works with blocks 
How can we use it on a file?
What happens if each block of a file is encrypted independently (ECB mode)
plaintext blocks 
ciphertext blocks 
In CBC mode, each encryption depends on previous blocks.
The CBC mode 
● “Cipher Block Chaining” 
○ considered secure 
○ we’ll use it from now on 
● introduces an Initialization Vector 
○ extra parameter 
○ arbitrary 
○ in practice, it should be unpredictable
key 
+ 
initialization vector 
X blocks 
X blocks
Relations between blocks and IV 
= ENC(IV ^ P1) 
C1 
* we use the same key for all operations. 
*
Relations between blocks and IV 
= 
= 
ENC(IV ^ P1) 
DEC(ENC(IV ^ P1)) 
C1 
DEC(C1) 
Decrypt both sides...
Relations between blocks and IV 
= 
= 
ENC(IV ^ P1) 
DEC(ENC(IV ^ P1)) 
C1 
DEC(C1) 
it cancels itself
Relations between blocks and IV 
= 
= 
ENC(IV ^ P1) 
IV ^ P1 
C1 
DEC(C1)
Relations between blocks and IV 
= 
= 
= 
ENC(IV ^ P1) 
IV ^ P1 
IV ^ P1 ^ P1 
C1 
DEC(C1) 
P1 ^ DEC(C1) 
Apply a XOR on both sides...
Relations between blocks and IV 
= 
= 
= 
ENC(IV ^ P1) 
IV ^ P1 
IV ^ P1 ^ P1 
C1 
DEC(C1) 
P1 ^ DEC(C1) 
...it cancels itself
Relations between blocks and IV 
= 
= 
= 
ENC(IV ^ P1) 
IV ^ P1 
IV 
C1 
DEC(C1) 
P1 ^ DEC(C1)
Relations between blocks and IV 
= 
= 
= 
= 
ENC(IV ^ P1) 
IV ^ P1 
IV 
P1 ^ DEC(C1) 
C1 
DEC(C1) 
P1 ^ DEC(C1) 
⇒ IV 
We get a relation of IV from P1 and C1
IV = P1 ^ DEC(C1) 
P1, C1 are the first 16 bytes of our 2 files 
once the key k is chosen, 
1. decrypt C1 
2. apply a XOR with P1 
⇒ we get the IV
key 
+ 
initialization vector 
X blocks 
X blocks 
k 
IV 
Px 
Cx
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
k 
IV 
P1 
C1
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
k 
IV 
P1 
C1 
IVManipulation!!
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
k 
IV 
P1 
C1 
IVManipulation!! 
P1 ^ DEC(C1)
IVManipulation!! 
r 1ÿ4┼╬ ╕·§{ú)u≡ 
(72 00 31 98 34 C5 CE 00 B8 FA 15 7B A3 29 75 F0) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
k 
IV 
P1 
C1
IVManipulation!! 
+ 
r 1ÿ4┼╬ ╕·§{ú)u≡ 
(72 00 31 98 34 C5 CE 00 B8 FA 15 7B A3 29 75 F0) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
ëPNG♪◙→◙ ♪IHDR 
(89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) 
k 
IV 
P1 
C1
Status 
● we control the first cipher block 
○ we can get a valid signature 
■ and 8 extra bytes 
● we control nothing else 
○ no valid structure
How can we control 
the structure via encryption?
If we encrypt our picture, we get random data.
If we append another picture to this random data...
… we get back our original picture after decryption. 
(followed by some different random data)
If we encrypt the final result, we get our first random data, 
followed by our target picture.
Pre-decrypt data 
● Decrypt our target’s chunks 
● Append them to our source file 
○ at the start of the next block 
(pad if necessary) 
○ it’s still valid thanks to the IEND chunk
Status 
● We control 
○ a bit of the input 
○ a bit of the output 
● The source file is still valid 
○ original source file (valid) 
○ followed by decrypted data
How can we control 
crypted data ?
We won’t☺ 
We’ll ask the file format to ignore it.
Adding a standard comment chunk (tEXt type)
The chunk position doesn’t matter.
Adding a completely custom bing chunk.
[warn] Skip parser 'PngFile': First chunk is not header 
The header chunk should be the first one. 
In practice, it doesn’t matter 
(except for Hachoir)
Recap 
Adding custom chunks: 
● lowercase type 
● chunk order doesn’t matter much 
⇒ we can add any extra data 
in a custom chunk
add a custom chunk to 
cover encrypted data 
⇒ it will be ignored 
⇒ the encrypted file will be valid!
Status 
We control after encryption: 
● the first block 
○ the signature (8 bytes) 
○ 8 extra bytes 
■ enough to declare a chunk 
(4 bytes of size + 4 bytes of type) 
● the chunks of the target 
○ by decrypting them in advance
“AngeCryption” 
with 2 files Source and Target, 
● create a Result file 
R shows 
● S, initially 
● T, after AES-CBC(key, IV) encryption
File layout
Step by step
Initial data 
We define the key, and the S and T files. 
key AngeCryptionKey! 
S 
T
Initial checks 
● S is a PNG 
○ the PNG format tolerates appended data 
● T is a PNG 
○ it allows custom chunks 
(at the beginning of the file, right after the signature) 
● S fits in a single chunk 
○ its size can be encoded in 4 bytes 
● AES-128 has a 16 bytes block size 
○ big enough to declare a chunk after the signature
Determine the first cipher block 
● R starts with P1, from S 
● once encrypted, R starts with: 
a. an 8 byte PNG signature 
b. a custom chunk 
■ that covers all the chunks from S 
1. S is 14022 bytes, so that’s 14016 bytes of chunks 
2. 14016 is encoded 000036c0 
■ with a custom type: rmll 
lowercase ⇒ ancillary ⇒ ignored 
First cipher block of R, C1: 
89 P N G r n 1A n 00 00 36 C0 r m l l 
Signature ------------- Length ----- Type ------
First plaintext / cipher blocks 
First block of R, P1: 
89 P N G r n 1A n 00 00 00 0D I H D R 
Signature ------------- Length ----- Type ------ 
First block of encrypted R, C1: 
89 P N G r n 1A n 00 00 36 C0 r m l l 
Signature ------------- Length ----- Type ------
Determine the IV 
We have the P1 & C1 blocks, and the key 
1. Decrypt C1 
2. XOR with P1 
We get the IV that will encrypt P1 into C1: 
78 D0 02 81 6B A7 C3 DE 88 DE 56 8F 6A 59 1D 06
Craft R 
The IV is determined. 
● Pad S to the next 16 bytes alignment 
● Encrypt via AES-CBC with our parameters 
→ with this IV, S will start with: 
(after encryption) 
1. a signature 
2. a rmll chunk (covering the rest of S)
Adjust the custom chunk 
1. Chunks end with a CRC32 
○ calculate it (using the encrypted data) 
2. Append T’s plaintext chunks 
3. Decrypt the result 
○ after padding
Result 
1. signature 
2. S chunks 
3. padding 
4. T chunks 
(pre-decrypted) 
0000: 89 50 4E 47-0D 0A 1A 0A-00 00 00 0D-49 48 44 52 ëPNG IHDR 
0010: 00 00 02 1A-00 00 00 BE-08 06 00 00-00 73 AB A6 + s½ª 
0020: F7 00 00 36-8D 49 44 41-54 58 C3 EC-D9 CB 7A D3 ˜ 6ìIDATX+8+-z+ 
0030: 66 02 C6 71-3A 9D 43 DB-95 9F 67 3A-09 98 10 4C f ¦q:¥C¦òƒg: ÿ L 
... 
36A0: F5 2D D0 30-33 33 33 BB-C4 3C 04 33-33 33 BB D8 )--0333+-< 333++ 
36B0: FE 07 A4 AD-F2 BC 37 7B-32 76 00 00-00 00 49 45 ¦ ñ¡=+7{2v IE 
36C0: 4E 44 AE 42-60 82 00 00-00 00 00 00-00 00 00 00 ND«B`é.......... 
36D0: 43 F7 62 F2-4C 6A 07 4D-03 41 82 84-3C D3 F4 39 C˜b=Lj M Aéä<+(9 
36E0: FC 27 90 6B-82 71 C8 34-3E 48 4D C1-4C 2A BB 96 n'Ékéq+4>HM-L*+û 
36F0: 3C 97 01 67-FE B3 E4 03-E9 09 B2 C3-7E 54 B7 23 <ù g¦¦S T ¦+~T+# 
3700: 57 37 3F 1E-DF 67 B3 E8-60 B3 EC A6-CA 51 61 11 W7? ¯g¦F`¦8ª-Qa 
... 
5CE0: CC 22 8A A0-EC 19 8C DD-26 79 03 29-03 90 93 F1 ¦"èá8 î¦&y ) Éô± 
5CF0: 41 CE 4F DB-C0 70 A5 74-D0 74 B7 2E-06 9B 48 7C A+O¦+pÑt-t+. ¢H| 
5D00: 2F A6 D1 ED-57 FB 88 67-D1 B0 10 4C-1C 6E CB 15 /ª-fWvêg-¦ L n-
1. signature 
2. custom chunk 
a. CRC32 
3. T chunks 
4. padding 
Encrypted result 
0000: 89 50 4E 47-0D 0A 1A 0A-00 00 36 C0-72 6D 6C 6C ëPNG 6+rmll 
0010: 9A 3E 30 1C-F1 D6 E1 41-B7 38 DB A1-5A 71 57 8F Ü>0 ±+ßA+8¦íZqWÅ 
0020: 6E 49 A0 D5-76 4C 33 7D-9B CA 44 B8-72 27 48 D9 nIá+vL3}¢-D+r'H+ 
0030: 64 20 A6 7F-38 D8 89 4A-9F 5F 92 45-17 5D 70 BA d ª8+ëJƒ_ÆE ]p¦ 
... 
36A0: 4D 1E 79 E7-9E F5 81 AC-0C 4C 3B 03-75 43 2B 15 M ytP)ü¼ L; uC+ 
36B0: B6 9F F4 32-E8 3C 02 67-96 DA 7B 1D-A8 E5 1E BF ¦ƒ(2F< gû+{ ¿s + 
36C0: D1 04 25 DF-E5 92 E3 62-30 9A F6 08-60 57 BC 5B - %¯sÆpb0Ü÷ `W+[ 
36D0: 98 38 F0 D6-00 00 00 0D-49 48 44 52-00 00 00 86 ÿ8=+ IHDR å 
36E0: 00 00 00 86-08 02 00 00-00 97 1B 65-C6 00 00 25 å ù e¦ % 
36F0: FE 49 44 41-54 78 5E D4-C0 C1 0A 00-10 0C 00 50 ¦IDATx^++- P 
3700: FF FF 6F CA-8D B8 A8 95-92 1C 56 0E-36 9B F9 0E o-ì+¿òÆ V 6¢· 
... 
5CE0: EE 4B 05 D4-46 49 B3 66-30 ED 6E BF-E7 23 7B C9 eK +FI¦f0fn+t#{+ 
5CF0: C8 D7 51 F8-99 B7 9C 00-00 00 00 49-45 4E 44 AE ++Q°Ö+£ IEND« 
5D00: 42 60 82 00-00 00 00 00-00 00 00 00-00 00 00 00 B`é.............
Generalized case 
The only requirements: 
● The source format tolerates appended data 
● The target format can fit a signature and chunk 
declaration in a single cipher block 
● S fits in a single target format chunk 
We can use other algorithms, 
both ways (encryption or decryption) 
with various file formats (even in the same file)
→ 
PoC||GTFO 0x3 is a PDF that you can encrypt into a PNG 
(and it shows its own IV)
For more information (PDF, JPG, GynCryption, PiP…): 
https://speakerdeck.com/ange/when-aes-equals-episode-v 
https://www.youtube.com/watch?v=wbHkVZfCNuE
Coming this fall...
Let’s play with TrueCrypt
TrueCrypt software 
● Creates and manages a virtual storage volume 
○ Encrypted 
○ Transparent for the system 
The volume is useless without the password.
ëPNG♪◙→◙ ♪IHDR 
☻→ ╛◘♠ s½ª 
≈ 6ìIDATX├∞┘╦z╙ 
╪ α ►JFIF ☺☺☺ ┤ 
┤ █ C ♠♦♣♠♣♦♠ 
♠♣♠••♠◘◙►◙◙○○◙¶♫ 
☼♀►↨¶↑↑↨¶▬▬→↔%▼→ 
←#∟▬▬ , #&')*)↓▼ 
-0-(0%()( █ C☺•• 
•◙◘◙‼◙◙‼(→▬→(((( 
(((((((((((((((( 
%PDF-1.3◙%─σ≥σδº 
≤á╨─╞◙4 0 obj◙<< 
/Length 5 0 R / 
Filter /FlateDec 
ode >>◙stream◙x☺ 
⌂ELF☺☻☺♥ 
☻ ¶ ☺ ▬:É 4 
4 ☻ ( 
☺ ► 
► ♠K¼ ♠K¼ ♣ 
☺ ☺ ∙Φ► ∙Φ 
► ∙Φ ♠ 
☺ ╣E)lUPX!↓◄♪ä 
ZIP JPG 
MZÉ ♥ ♦ 
╕ @ 
◘☺ 
♫▼║♫ ┤○═!╕☺L═!Th 
is program canno 
t be run in DOS 
mode.♪♪◙$ 
PK♥♦¶ ◘ î◄|>á# 
SÇ≈♀ ♫∟ ↕ Cl 
ftypisom ☻ 
isomiso2avc1mp41 
*freevideo se 
rved by mod_h264 
_streaming ▲¿<mo 
ov lmvhd |% 
░Ç|%░Ç ♥Φ ),( ☺ 
PE 
Standard file format headers
d/Γ↨jôù☺♫Ö▲b¶n0ï 
∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ► 
-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+ 
m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦ 
♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l 
┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ 
ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m' 
(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~ 
░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ 
¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢ 
▬£÷Cd▼├à·3g~Bêc┌ 
MΦvεÖ/à╕⌂Ñ9ôΓ≈♫╤ 
┐╩P┴╥F¥0½╙'*"ú▌◙ 
¡╔^è¼¶│ÅDN▌♀♂¬↨♠ 
!>τ╡⌐A!┬W`δÜp£]₧ 
Y≡yí#û?♥╞-î§yY¶╖ 
○σï½Ü◙E¬"╫⌂2Θ♠╨6 
⌡ù@e7▲▬▌╒<╤TQTHΩ 
Ω╟╬ìPδW9▀8◄Σê♫╨Ω 
♦♠Æ►♂r▬╜E╣&╚☻⌠¬░ 
πa ┐╪å<6▀vMR6₧☻: 
♦: n┬F≡_τ╝╫╦≡m▌▬ 
┬ô£Ç`☼Jl◘∞• ÿ╗≥∞ 
╒[►y♠→↨Ñà╩t‼╫α┬Å 
J·¶ë├α♫╠◄Θi_╥I╗╗ 
≤╟úKû•=┘╩☺§§.rΩP 
≥↔?{♠àQ{╓◘≈┼╜╕|½ 
Q&f►∞Ü→▄σÖσû►↑¶4 
╜>e#TrÄ5 HòƒÑV▄║ 
▬╤íΦDi╔)↑â←Ü─+┌∞ 
Kd(¢╚ñ╖¢MTac■▌l± 
é«Cñ─=¿N_↨N►♫φÅε 
╔o╧Y1Z$Σ▬╨h╬a¥¼j 
↓M¬┐Y#°h≡¿?σ┬♀c| 
▀;P,→k;Q^▄x▓α▌½┬ 
│7e9"⌡ÆΦ╬▓ⁿD²#Ç▼ 
═«↓⌐☻┐Σü╘∟¼î¼╟ùI 
è╖$Aσ♣²=ß>└▀K∩τì 
0►n#ƒ☼ⁿs@ ♫0-X▀☼ 
₧w,ΓòR☻ù♠○├ï☻s○x 
±Σ.hƒ9◄▒5w♣☼⌠○▬â 
+ÑΣ≈↕▀┘τ╗ N¼ciâ% 
I╤l►éLóO8♣±Çs▀○↨ 
☺╔i╪.~¶Ge╢Ög╗█÷* 
‼Vö▀%.í÷# 3éÑûÇ♦ 
δ═├CμO*$M▲ç5{Z?φ 
τΦL├{╗ùΦ▲²÷═ⁿW╗P 
/¼◙^←[│╣¡ xÉμ1hF 
Headers of different TrueCrypt files.
Random contents? 
A file format designed not to be identified 
● except if you have the password 
● random appearance 
○ you can deny it’s a TrueCrypt volume 
● there is a header 
○ but it’s encrypted
TRUE ♣• Iî$B 
É ☻ É ☻ 
C¬α╔Ñ 
«ÑêI█⌠▬♀D╣▼xΦm↓¬0τzP°W5» 
╣FcJl¼∙L¢▒9Oä° 
τEpó&←╠¿oμÆ☺▬ìä5Θä↨_○¼I┐¡ 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
A TrueCrypt header, before and after decryption.
How many files do you have 
that are 100% random? 
it’s not so stealthy
Potential volumes detection 
● no known header 
● “big size” 
● size rounded to 512 
● random content from the start 
○ very high entropy
Just a password? 
If encryption only depends on the password, 
TrueCrypt is vulnerable to rainbow * 
table attacks. 
* pre-computed tables (to make faster attacks)
Salt 
The file starts with 64 bytes of salt: 
● random data 
● combined with the password 
● used to decrypt the header 
⇒ no possible pre-computing 
⇒ rainbow tables are useless
d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
Salt 
(to decrypt the header) 
Header 
● crypted with salt and password 
● contains the key used to decrypt the volume 
Volume 
● encrypted with the key in the header 
Structure of a TrueCrypt volume
If we modify the salt, 
we just have to 
to re-crypt the header 
no need to change the volume itself 
(the volume key hasn’t changed)
Idea: 
Integrate a TrueCrypt volume 
into another file 
- stealthier 
- both formats stay valid
Strategy 
1. Modify the host to make free space 
near the beginning 
○ create a custom chunk to contain the volume 
2. Copy the header and the volume’s content 
○ the decrypted header hasn’t changed, 
and the volume hasn’t either 
3. Decrypt the header 
○ with the initial salt 
4. Re-crypt the header 
○ with the salt from the start of the host 
5. Adjust the CRC of the chunk 
○ optional, as the chunk is ancillary
ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª 
≈ 6ìIDATX├∞┘╦z╙f☻╞q:¥C█òƒg:○ÿ►L 
τ♠╝₧Æáp╩njB╚üC►▌╡Ñ┼ä╬^wα←h►9┴∞|♣ 
Eí7α⌡äâÆmí╚w≡═√╔û-┘Æ¡ôc[~▀τ∙»║¬∞ 
∩╦☼∙ö►Γ¶cî1╞╪ ΓC`î1╞╪`í1i¢yl)▓│e 
K│{dUæ!╦?▓jHtvμ'ºÅ₧N °╤Då½◙╥ª←)▓ 
S∟╟q∟7⌐╦24╬=╢◙¿ä4└┬@&↕N@FúGφ≥☺⌡Ç 
åo╙■↓╙☼ ╨æå¶öπ7Éπ8Ä#4╞d│¢⌡┬∞ªU♠, 
¬╚D┬i╞º▬4B`#%h◘αó3│ëÅ≥╘├☼E~#9Äπ8 
Bcäv~│^☻0*╚DBμ♠F/lDüF←←⌐Cú§á!ª~° 
`!↔⌐êo<8Äπ8Bc◘╕PÉļ≤Mx♂•ìx?ƒ♀∟→ 
¥U%:■±=╤┴q▄Σφïτ▀ΩHx┌wzαm»G╗25|;≈ 
k|·‼♠ì┬ôz☺i╚ö╕p7Lh♦a#64ⁿ▒! ♪⌠╛èJ 
ⁿ╓r∟7◄╚x☺d╝ (:kíπü╖²▲┘αP╗≤çFφï↔ò 
╕¢¶h ▬◙╥æpΩä╞∙‼àå5Lh8Y¿é◙ⁿ♠s∟ùI 
dⁿ7 ↓/:▐nñ☼ì→"2&☺→↨~«+╚p♥#<4Ω╛╨p 
a├D♠╥Ç♀Ö☻`┤╩•♦dáÅeñí◙2É↓ΘτôD╨≡`├ 
I╛σP°Mμ8.+√ⁿ┼╖:↕v╧♥┌wzαm/á]Ö┌▌ĺ 
┌τ|ôæ}h|╒♦♠↕Nqá╤±Vúè44░?╚Çàé╩HGμ 
○BC|∙¥¥ü◘♫Äπ▓âîôà♠ææuh ↑Ed|σ☻F►4 
ⁿ░╤☺♪♂╨╨☺ï╥░■⌂Çè"*ú┌○Aâαα8n2ɱ< 
↓±íAdd↓→ÇE♫Θ↕↑N○áQEÑQ{╞ Fíë♫≤♦áA 
pp∟7v√♀╚°∞┼♥ßΘy@√Njw{☺φ╩εw╖s┐åêî 
d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
TrueCrypt volume Image
ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª 
≈ ♦Å╫true 
d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
Create free space in the file to host the volume.
d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª 
≈ ♦Å╫true 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
⇒ 
Copy the volume in the created space.
d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª 
≈ ♦Å╫true 
TRUE ♣• Iî$B 
É ☻ É ☻ 
C¬α╔Ñ«ÑêI█⌠▬♀D╣▼xΦm↓¬0τzP°W5»╣Fc 
Jl¼∙L¢▒9Oä°τEpó&←╠¿oμÆ☺▬ìä5Θä↨_○ 
¼I┐¡ 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
Decrypt the header with the volume’s salt.
d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö 
┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö 
╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ 
U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ 
»Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî 
Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( 
ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î 
üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ 
┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω 
L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ 
Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ 
╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É 
bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* 
╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å 
▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ 
♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª 
≈ ♦Å╫true 
┤♣▒εÜ┘$φ╗3☼»αG↔öÇ═0₧:P╞!•▒áwó░« 
u∟╔AL╙J<►Φs L╣I▌èαè3l?WÑû╠♠ìΣ}⌂ 
n°ôaîlö§╔ó¢i∞¬∩╦8≡)≤Çg╘╩┴3ëΓ%◄/( 
b☻▬↔‼⌐j☻♥dæ╧↔ä♪┘┬ì §(▒┌:╞ùxº╟║∞◄ 
á◄űn≤ó± ►¶Jp/♀α/♠P☼zz(≤ÿ╩↔ï┼§•ô 
,∟+╙aμ─CΩ⌐‼÷α░s╕Å':òφw≡O»♀1▓z♣&ñ 
y╔╕à"IX≤▄ⁿJ♣║PÑnö¿╣τ┴7à&ªü>¬ï║Wx 
w^╚>à►mtûσf√•wâ╗╥²┼xÿáôùε▄ôτô≤█≥ 
╩┌Aj≤⌐¢╟╬M┬ûí δτ╩~⌐Pl¶¼┌╢!zWÅuδ$ 
/≥Ñw╒V♀WR┤V╥°╔═√=¼7°²√▲┼kd√Fösùc 
█◘k├o¬åù♂r╢§F╙◘≥|MÖP;@∞↑xäεù→æ½ 
r♦«▐R≥óå2♦ô&═τ'5$¼♫π╥÷èzef¥Uí`∙j 
╪'¬├Rö`ÿ¶óB≤╪2⌠↑RmâÖ▐¡╝→‼pò[│k«╗ 
å;·L→pÜ│bzÖ=b¬S~û|¶¿î╩G╢ç╖¼ ‼«ö♠ 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
Encrypt the header with the salt from the host.
ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª 
≈ ♦Å╫true 
┤♣▒εÜ┘$φ╗3☼»αG↔öÇ═0₧:P╞!•▒áwó░« 
u∟╔AL╙J<►Φs L╣I▌èαè3l?WÑû╠♠ìΣ}⌂ 
n°ôaîlö§╔ó¢i∞¬∩╦8≡)≤Çg╘╩┴3ëΓ%◄/( 
b☻▬↔‼⌐j☻♥dæ╧↔ä♪┘┬ì §(▒┌:╞ùxº╟║∞◄ 
á◄űn≤ó± ►¶Jp/♀α/♠P☼zz(≤ÿ╩↔ï┼§•ô 
,∟+╙aμ─CΩ⌐‼÷α░s╕Å':òφw≡O»♀1▓z♣&ñ 
y╔╕à"IX≤▄ⁿJ♣║PÑnö¿╣τ┴7à&ªü>¬ï║Wx 
w^╚>à►mtûσf√•wâ╗╥²┼xÿáôùε▄ôτô≤█≥ 
╩┌Aj≤⌐¢╟╬M┬ûí δτ╩~⌐Pl¶¼┌╢!zWÅuδ$ 
/≥Ñw╒V♀WR┤V╥°╔═√=¼7°²√▲┼kd√Fösùc 
█◘k├o¬åù♂r╢§F╙◘≥|MÖP;@∞↑xäεù→æ½ 
r♦«▐R≥óå2♦ô&═τ'5$¼♫π╥÷èzef¥Uí`∙j 
╪'¬├Rö`ÿ¶óB≤╪2⌠↑RmâÖ▐¡╝→‼pò[│k«╗ 
å;·L→pÜ│bzÖ=b¬S~û|¶¿î╩G╢ç╖¼ ‼«ö♠ 
Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ 
▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i 
ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê 
↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ 
↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ 
äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D 
... 
Sal 
TrueCrypt PNG 
Header 
Volume’s content 
End of volume 
Image (ignored) 
Signature + header 
Chunk declaration 
Chunk data 
Chunk end 
Original chunks
TrueCrypt volumes in standard files 
(still useable and modifiable)
Conclusion 1/2 
● We can add extra data in a standard binary file 
● This data can be: 
○ another standard file, after en/decryption 
○ a TrueCrypt volume
Conclusion 2/2 
● No need to understand everything 
to have fun with crypto 
● Better progress step by step 
○ ask an expert 
○ hard to debug 
● Encrypted doesn’t mean random 
● examples: http://bit.ly/1n63yKP 
(http://corkami.googlecode.com/svn/trunk/src/angecryption/rmll)
Acknowledgments 
@veorq @doegox @iamreddave 
@miaubiz @travisgoodspeed @sergeybratus 
@cynicalsecurity @rantyben @thegrugq 
@skier_t @jvanegue @kaepora @munin 
@joernchen @andreasdotorg @tabascoeye 
@cryptax @pinkflawd @push_pnx @gynvael 
@rfidiot @cbrocas @kennwhite...
@angealbertini 
corkami.com 
Damn, that's the second time those alien bastards shot up my ride!

More Related Content

PDF
Let's play with crypto!
PDF
Cryptography 202
PPTX
Hash functions
PDF
Как мы охотимся на гонки (data races) или «найди багу до того, как она нашла ...
PDF
Intro to Rust from Applicative / NY Meetup
PDF
Guaranteeing Memory Safety in Rust
PDF
Rust tutorial from Boston Meetup 2015-07-22
PDF
The Ring programming language version 1.10 book - Part 38 of 212
Let's play with crypto!
Cryptography 202
Hash functions
Как мы охотимся на гонки (data races) или «найди багу до того, как она нашла ...
Intro to Rust from Applicative / NY Meetup
Guaranteeing Memory Safety in Rust
Rust tutorial from Boston Meetup 2015-07-22
The Ring programming language version 1.10 book - Part 38 of 212

What's hot (12)

PPTX
What is Bitcoin? - While42 (03/25/15)
PPTX
Token btlcoin money
PPTX
Token btlcoin electronic money
PDF
apidays LIVE New York - WT* is JWT? by Maciej Treder
PDF
Rust: Reach Further (from QCon Sao Paolo 2018)
PDF
Clojure Small Intro
PDF
Advanced Encryption Standard Algorithm
PDF
Степан Кольцов — Message passing: многопоточное программирование без мьютексов
PDF
Algorithm (MAC/GCM/GMAC)
PDF
Some examples of the 64-bit code errors
PDF
Everything I always wanted to know about crypto, but never thought I'd unders...
PDF
The Ring programming language version 1.5.4 book - Part 37 of 185
What is Bitcoin? - While42 (03/25/15)
Token btlcoin money
Token btlcoin electronic money
apidays LIVE New York - WT* is JWT? by Maciej Treder
Rust: Reach Further (from QCon Sao Paolo 2018)
Clojure Small Intro
Advanced Encryption Standard Algorithm
Степан Кольцов — Message passing: многопоточное программирование без мьютексов
Algorithm (MAC/GCM/GMAC)
Some examples of the 64-bit code errors
Everything I always wanted to know about crypto, but never thought I'd unders...
The Ring programming language version 1.5.4 book - Part 37 of 185
Ad

Similar to Let's play with crypto! v2 (20)

PDF
when AES(☢) = ☠ --- a crypto-binary magic trick
PDF
When AES(☢) = ☠ - Episode V
PDF
Funky file formats - 31c3
PDF
Exploiting Cryptographic Misuse - An Example
PDF
SymmetricCryptography-Part3 - Tagged.pdf
PDF
Don't Give Credit: Hacking Arcade Machines
PDF
Hidden in Plain Sight: DUAL_EC_DRBG 'n stuff
PPTX
Trible data encryption standard (3DES)
PDF
Schizophrenic files v2
PPTX
lec20111111111111111111111111111111111111.pptx
PDF
hashdays 2011: Ange Albertini - Such a weird processor - messing with x86 opc...
PDF
3 Basics of Cryptography Basics of Cryptography
PPTX
Crypto-Presentation jfjfd dkfdnfdj kdfjdjfdjkfd .pptx
PDF
03 UNIT-2.pdf
PPTX
Data Encryption standard in cryptography
PPTX
Why learn Internals?
PDF
Protostar VM - Heap3
PDF
from Binary to Binary: How Qemu Works
PDF
got HW crypto-slides_hardwear
PDF
Efficient Data Storage for Analytics with Apache Parquet 2.0
when AES(☢) = ☠ --- a crypto-binary magic trick
When AES(☢) = ☠ - Episode V
Funky file formats - 31c3
Exploiting Cryptographic Misuse - An Example
SymmetricCryptography-Part3 - Tagged.pdf
Don't Give Credit: Hacking Arcade Machines
Hidden in Plain Sight: DUAL_EC_DRBG 'n stuff
Trible data encryption standard (3DES)
Schizophrenic files v2
lec20111111111111111111111111111111111111.pptx
hashdays 2011: Ange Albertini - Such a weird processor - messing with x86 opc...
3 Basics of Cryptography Basics of Cryptography
Crypto-Presentation jfjfd dkfdnfdj kdfjdjfdjkfd .pptx
03 UNIT-2.pdf
Data Encryption standard in cryptography
Why learn Internals?
Protostar VM - Heap3
from Binary to Binary: How Qemu Works
got HW crypto-slides_hardwear
Efficient Data Storage for Analytics with Apache Parquet 2.0
Ad

More from Ange Albertini (20)

PDF
Overview of file type identifiers (HackLu)
PDF
A question of time - Troopers 2024 Keynote
PDF
Technical challenges with file formats
PDF
Relations between archive formats
PDF
Abusing archive file formats
PDF
TimeCryption
PDF
You are *not* an idiot
PDF
Improving file formats
PDF
KILL MD5
PDF
No more dumb hex!
PDF
Beyond your studies
PDF
An introduction to inkscape
PDF
The challenges of file formats
PDF
Exploiting hash collisions
PDF
Infosec & failures
PDF
Connecting communities
PDF
TASBot - the perfectionist
PDF
Caring for file formats
PDF
Hacks in video games
PDF
Trusting files (and their formats)
Overview of file type identifiers (HackLu)
A question of time - Troopers 2024 Keynote
Technical challenges with file formats
Relations between archive formats
Abusing archive file formats
TimeCryption
You are *not* an idiot
Improving file formats
KILL MD5
No more dumb hex!
Beyond your studies
An introduction to inkscape
The challenges of file formats
Exploiting hash collisions
Infosec & failures
Connecting communities
TASBot - the perfectionist
Caring for file formats
Hacks in video games
Trusting files (and their formats)

Recently uploaded (20)

PPT
Teaching material agriculture food technology
PDF
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PPTX
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
PDF
Electronic commerce courselecture one. Pdf
PPTX
Big Data Technologies - Introduction.pptx
PDF
Empathic Computing: Creating Shared Understanding
PDF
KodekX | Application Modernization Development
PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PPTX
Spectroscopy.pptx food analysis technology
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
cuic standard and advanced reporting.pdf
PPTX
sap open course for s4hana steps from ECC to s4
PDF
Encapsulation theory and applications.pdf
Teaching material agriculture food technology
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
The Rise and Fall of 3GPP – Time for a Sabbatical?
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
Electronic commerce courselecture one. Pdf
Big Data Technologies - Introduction.pptx
Empathic Computing: Creating Shared Understanding
KodekX | Application Modernization Development
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
Agricultural_Statistics_at_a_Glance_2022_0.pdf
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Spectroscopy.pptx food analysis technology
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Understanding_Digital_Forensics_Presentation.pptx
Dropbox Q2 2025 Financial Results & Investor Presentation
cuic standard and advanced reporting.pdf
sap open course for s4hana steps from ECC to s4
Encapsulation theory and applications.pdf

Let's play with crypto! v2

  • 1. let’s play with crypto! Ange Albertini MetaRheinMainConstructionDays MRMCD 5-7 september 2014 HS Darmstadt www.mrmcd.net 2014/09/05
  • 2. Ange Albertini reverse engineering & visual documentations @angealbertini ange@corkami.com http://www.corkami.com
  • 3. an encrypted file is not always encrypted
  • 4. encrypt(file) an encrypted file is not always encrypted random
  • 5. Let’s take an example: this is a JPEG picture...
  • 6. AES( ) ...if you encrypt it with AES...
  • 7. … you get this PNG picture...
  • 8. 3DES( ) ...and if you decrypt it with Triple DES...
  • 9. ...you get a PDF document.
  • 10. Don’t worry! I’ll keep it simple...
  • 11. ...because crypto is (too) hard!
  • 12. HORROR And this is my usual reaction...
  • 13. ...but I can still have fun with it...
  • 14. PNG TrueCrypt Crypto ...so let’s play together !
  • 16. 1 block (16 bytes)
  • 17. 1 block (16 bytes) + 1 key (16 bytes)* * in the case of AES-128, so from now on, we’ll say AES for AES-128.
  • 18. 1 block (16 bytes) + 1 key (16 bytes) 1 block (16 bytes)
  • 19. a block of text. + MySecretKey12345 ┐◄n╩i▐☼←∞└╞∙iû╨► (BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
  • 20. a block of text. + MySecretKey12346 gO┼╗ÑëΩcë ▼LÇk╨î (67 4F C5 BB A5 89 EA 63 89 20 1F 4C 80 6B D0 8C)
  • 21. a block of text! + MySecretKey12345 wε╩▬▄y&↕ú@αùαφ♣O (77 EE CA 16 DC 79 26 12 A3 40 E0 97 E0 ED 05 4F)
  • 22. Any change in the key or input block gives a completely different output
  • 23. we can’t control the output the differences are unpredictable
  • 25. a block of text. + MySecretKey12345 encryption ┐◄n╩i▐☼←∞└╞∙iû╨► (BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
  • 26. a block of text. decryption MySecretKey12345 + ┐◄n╩i▐☼←∞└╞∙iû╨► (BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
  • 27. π╔6I►♣♫Σ♣╝╤→√çφ╡ (E3 C9 36 49 10 05 0E E4 05 BC D1 1A FB 87 ED B5) decryption MySecretKey12346 + ┐◄n╩i▐☼←∞└╞∙iû╨► (BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
  • 28. outwith the encryption key, we can restore the original block
  • 29. without the encryption key, we can’t do anything with the encrypted block
  • 30. “plaintext” and “crypted” are just names encryption ⇔ decryption are just inverse functions
  • 31. a block of text. + MySecretKey12345 encryption ┐◄n╩i▐☼←∞└╞∙iû╨► (BF 11 6E CA 69 DE 0F 1B EC C0 C6 F9 69 96 D0 10)
  • 32. a block of text. + MySecretKey12345 decryption ä/ë-╦7 ↓h│☻⌂μ[←Ñ (84 2F 89 2D CB 37 00 19 68 B3 02 7F E6 5B 1B A5)
  • 33. a block of text. encryption MySecretKey12345 + ä/ë-╦7 ↓h│☻⌂μ[←Ñ (84 2F 89 2D CB 37 00 19 68 B3 02 7F E6 5B 1B A5)
  • 34. we can decrypt plaintext we recover the original block via encryption ⇒ we can control encryption output
  • 35. Recap ● AES encrypts a block ○ we don’t control the output ● an encrypted block can be restored ○ with the encryption key ● encryption ⇔ decryption are just inverse functions ○ we can decrypt plaintext ○ we can recover the original block via encryption ● we can’t control both input and output ○ one, or the other
  • 36. Now, let’s talk about...
  • 37. This is a cow. This is how a users see it.
  • 38. This is how an expert sees a cow. It’s still the same cow, but it has some internal structure.
  • 39. Let’s work with a simplified structure of beef chunks.
  • 40. If our cow swallows a microSD, it’s still a valid cow! Even if it contains foreign data, that is tolerated by the system.
  • 41. Now, let’s look at the Portable Network Graphics format.
  • 42. Chunk ● The format is made of variable-sized pieces ○ critical or ancillary ● Common high-level structure ○ independent of the content and its interpretation ⇒ Store proprietary information while ⇒ guaranteeing a minimal compatibility
  • 44. A tool for computer butchers. (we’ll use it from now on) (’hachoir’ = meatgrinder)
  • 45. The Google logo, viewed in Hachoir: a signature, then a sequence of chunks.
  • 46. x89 P N G r n ^Z n Compulsory signature at offset 0 ● identify the file type ● identify transfer errors ○ x89 : non ASCII (ASCII = [0 - 128]) ○ rn then n : different end of line standards ○ ^Z (x1A) : “End Of File”
  • 47. Chunk ● Common structure: a. size, on 4 bytes b. type, made of 4 letters ■ 1st letter: lowercase ⇒ ancillary chunk c. data d. checksum ■ CRC32(type + data) ● We can add custom chunks
  • 48. IHDR chunk: containing image information
  • 49. IDAT chunk (compressed): pixels values
  • 50. IDAT after decompression (FF FF FF 00 = black + 100% transparent)
  • 51. IEND chunk: End of File (‘s structure)
  • 52. What comes after IEND is ignored by PNG tools. (the image is complete)
  • 53. Recap Structure: 1. Signature at offset 0 2. Chunks sequence a. IHDR header b. IDAT data c. IEND end
  • 54. “I know how Google works!” Now, you can impress your friends!
  • 55. ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) + MySecretKey12345 :¼N?â?pzILá+?ìgU (3A AC 4E 10 83 03 70 7A 49 4C A0 DA 0B 8D 67 55) Encryption breaks the signature.
  • 56. logo11w.png: PNG image data, 538 x 190, 8-bit/color RGBA, non-interlaced + MySecretKey12345 crypted.png: ISO-8859 text, with no line terminators Without a signature, the encrypted file is invalid.
  • 57. If we encrypt a PNG, we don’t get a PNG the signature is broken and the structure too (a priori)
  • 58. How can we encrypt oogle into uc?k duckdu ckgo
  • 59. How can we control input and output?
  • 60. AES works with blocks How can we use it on a file?
  • 61. What happens if each block of a file is encrypted independently (ECB mode)
  • 62. plaintext blocks ciphertext blocks In CBC mode, each encryption depends on previous blocks.
  • 63. The CBC mode ● “Cipher Block Chaining” ○ considered secure ○ we’ll use it from now on ● introduces an Initialization Vector ○ extra parameter ○ arbitrary ○ in practice, it should be unpredictable
  • 64. key + initialization vector X blocks X blocks
  • 65. Relations between blocks and IV = ENC(IV ^ P1) C1 * we use the same key for all operations. *
  • 66. Relations between blocks and IV = = ENC(IV ^ P1) DEC(ENC(IV ^ P1)) C1 DEC(C1) Decrypt both sides...
  • 67. Relations between blocks and IV = = ENC(IV ^ P1) DEC(ENC(IV ^ P1)) C1 DEC(C1) it cancels itself
  • 68. Relations between blocks and IV = = ENC(IV ^ P1) IV ^ P1 C1 DEC(C1)
  • 69. Relations between blocks and IV = = = ENC(IV ^ P1) IV ^ P1 IV ^ P1 ^ P1 C1 DEC(C1) P1 ^ DEC(C1) Apply a XOR on both sides...
  • 70. Relations between blocks and IV = = = ENC(IV ^ P1) IV ^ P1 IV ^ P1 ^ P1 C1 DEC(C1) P1 ^ DEC(C1) ...it cancels itself
  • 71. Relations between blocks and IV = = = ENC(IV ^ P1) IV ^ P1 IV C1 DEC(C1) P1 ^ DEC(C1)
  • 72. Relations between blocks and IV = = = = ENC(IV ^ P1) IV ^ P1 IV P1 ^ DEC(C1) C1 DEC(C1) P1 ^ DEC(C1) ⇒ IV We get a relation of IV from P1 and C1
  • 73. IV = P1 ^ DEC(C1) P1, C1 are the first 16 bytes of our 2 files once the key k is chosen, 1. decrypt C1 2. apply a XOR with P1 ⇒ we get the IV
  • 74. key + initialization vector X blocks X blocks k IV Px Cx
  • 75. ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) k IV P1 C1
  • 76. ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) k IV P1 C1 IVManipulation!!
  • 77. ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) k IV P1 C1 IVManipulation!! P1 ^ DEC(C1)
  • 78. IVManipulation!! r 1ÿ4┼╬ ╕·§{ú)u≡ (72 00 31 98 34 C5 CE 00 B8 FA 15 7B A3 29 75 F0) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) k IV P1 C1
  • 79. IVManipulation!! + r 1ÿ4┼╬ ╕·§{ú)u≡ (72 00 31 98 34 C5 CE 00 B8 FA 15 7B A3 29 75 F0) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) ëPNG♪◙→◙ ♪IHDR (89 50 4E 47 0D 0A 1A 0A 00 00 00 0D 49 48 44 52) k IV P1 C1
  • 80. Status ● we control the first cipher block ○ we can get a valid signature ■ and 8 extra bytes ● we control nothing else ○ no valid structure
  • 81. How can we control the structure via encryption?
  • 82. If we encrypt our picture, we get random data.
  • 83. If we append another picture to this random data...
  • 84. … we get back our original picture after decryption. (followed by some different random data)
  • 85. If we encrypt the final result, we get our first random data, followed by our target picture.
  • 86. Pre-decrypt data ● Decrypt our target’s chunks ● Append them to our source file ○ at the start of the next block (pad if necessary) ○ it’s still valid thanks to the IEND chunk
  • 87. Status ● We control ○ a bit of the input ○ a bit of the output ● The source file is still valid ○ original source file (valid) ○ followed by decrypted data
  • 88. How can we control crypted data ?
  • 89. We won’t☺ We’ll ask the file format to ignore it.
  • 90. Adding a standard comment chunk (tEXt type)
  • 91. The chunk position doesn’t matter.
  • 92. Adding a completely custom bing chunk.
  • 93. [warn] Skip parser 'PngFile': First chunk is not header The header chunk should be the first one. In practice, it doesn’t matter (except for Hachoir)
  • 94. Recap Adding custom chunks: ● lowercase type ● chunk order doesn’t matter much ⇒ we can add any extra data in a custom chunk
  • 95. add a custom chunk to cover encrypted data ⇒ it will be ignored ⇒ the encrypted file will be valid!
  • 96. Status We control after encryption: ● the first block ○ the signature (8 bytes) ○ 8 extra bytes ■ enough to declare a chunk (4 bytes of size + 4 bytes of type) ● the chunks of the target ○ by decrypting them in advance
  • 97. “AngeCryption” with 2 files Source and Target, ● create a Result file R shows ● S, initially ● T, after AES-CBC(key, IV) encryption
  • 100. Initial data We define the key, and the S and T files. key AngeCryptionKey! S T
  • 101. Initial checks ● S is a PNG ○ the PNG format tolerates appended data ● T is a PNG ○ it allows custom chunks (at the beginning of the file, right after the signature) ● S fits in a single chunk ○ its size can be encoded in 4 bytes ● AES-128 has a 16 bytes block size ○ big enough to declare a chunk after the signature
  • 102. Determine the first cipher block ● R starts with P1, from S ● once encrypted, R starts with: a. an 8 byte PNG signature b. a custom chunk ■ that covers all the chunks from S 1. S is 14022 bytes, so that’s 14016 bytes of chunks 2. 14016 is encoded 000036c0 ■ with a custom type: rmll lowercase ⇒ ancillary ⇒ ignored First cipher block of R, C1: 89 P N G r n 1A n 00 00 36 C0 r m l l Signature ------------- Length ----- Type ------
  • 103. First plaintext / cipher blocks First block of R, P1: 89 P N G r n 1A n 00 00 00 0D I H D R Signature ------------- Length ----- Type ------ First block of encrypted R, C1: 89 P N G r n 1A n 00 00 36 C0 r m l l Signature ------------- Length ----- Type ------
  • 104. Determine the IV We have the P1 & C1 blocks, and the key 1. Decrypt C1 2. XOR with P1 We get the IV that will encrypt P1 into C1: 78 D0 02 81 6B A7 C3 DE 88 DE 56 8F 6A 59 1D 06
  • 105. Craft R The IV is determined. ● Pad S to the next 16 bytes alignment ● Encrypt via AES-CBC with our parameters → with this IV, S will start with: (after encryption) 1. a signature 2. a rmll chunk (covering the rest of S)
  • 106. Adjust the custom chunk 1. Chunks end with a CRC32 ○ calculate it (using the encrypted data) 2. Append T’s plaintext chunks 3. Decrypt the result ○ after padding
  • 107. Result 1. signature 2. S chunks 3. padding 4. T chunks (pre-decrypted) 0000: 89 50 4E 47-0D 0A 1A 0A-00 00 00 0D-49 48 44 52 ëPNG IHDR 0010: 00 00 02 1A-00 00 00 BE-08 06 00 00-00 73 AB A6 + s½ª 0020: F7 00 00 36-8D 49 44 41-54 58 C3 EC-D9 CB 7A D3 ˜ 6ìIDATX+8+-z+ 0030: 66 02 C6 71-3A 9D 43 DB-95 9F 67 3A-09 98 10 4C f ¦q:¥C¦òƒg: ÿ L ... 36A0: F5 2D D0 30-33 33 33 BB-C4 3C 04 33-33 33 BB D8 )--0333+-< 333++ 36B0: FE 07 A4 AD-F2 BC 37 7B-32 76 00 00-00 00 49 45 ¦ ñ¡=+7{2v IE 36C0: 4E 44 AE 42-60 82 00 00-00 00 00 00-00 00 00 00 ND«B`é.......... 36D0: 43 F7 62 F2-4C 6A 07 4D-03 41 82 84-3C D3 F4 39 C˜b=Lj M Aéä<+(9 36E0: FC 27 90 6B-82 71 C8 34-3E 48 4D C1-4C 2A BB 96 n'Ékéq+4>HM-L*+û 36F0: 3C 97 01 67-FE B3 E4 03-E9 09 B2 C3-7E 54 B7 23 <ù g¦¦S T ¦+~T+# 3700: 57 37 3F 1E-DF 67 B3 E8-60 B3 EC A6-CA 51 61 11 W7? ¯g¦F`¦8ª-Qa ... 5CE0: CC 22 8A A0-EC 19 8C DD-26 79 03 29-03 90 93 F1 ¦"èá8 î¦&y ) Éô± 5CF0: 41 CE 4F DB-C0 70 A5 74-D0 74 B7 2E-06 9B 48 7C A+O¦+pÑt-t+. ¢H| 5D00: 2F A6 D1 ED-57 FB 88 67-D1 B0 10 4C-1C 6E CB 15 /ª-fWvêg-¦ L n-
  • 108. 1. signature 2. custom chunk a. CRC32 3. T chunks 4. padding Encrypted result 0000: 89 50 4E 47-0D 0A 1A 0A-00 00 36 C0-72 6D 6C 6C ëPNG 6+rmll 0010: 9A 3E 30 1C-F1 D6 E1 41-B7 38 DB A1-5A 71 57 8F Ü>0 ±+ßA+8¦íZqWÅ 0020: 6E 49 A0 D5-76 4C 33 7D-9B CA 44 B8-72 27 48 D9 nIá+vL3}¢-D+r'H+ 0030: 64 20 A6 7F-38 D8 89 4A-9F 5F 92 45-17 5D 70 BA d ª8+ëJƒ_ÆE ]p¦ ... 36A0: 4D 1E 79 E7-9E F5 81 AC-0C 4C 3B 03-75 43 2B 15 M ytP)ü¼ L; uC+ 36B0: B6 9F F4 32-E8 3C 02 67-96 DA 7B 1D-A8 E5 1E BF ¦ƒ(2F< gû+{ ¿s + 36C0: D1 04 25 DF-E5 92 E3 62-30 9A F6 08-60 57 BC 5B - %¯sÆpb0Ü÷ `W+[ 36D0: 98 38 F0 D6-00 00 00 0D-49 48 44 52-00 00 00 86 ÿ8=+ IHDR å 36E0: 00 00 00 86-08 02 00 00-00 97 1B 65-C6 00 00 25 å ù e¦ % 36F0: FE 49 44 41-54 78 5E D4-C0 C1 0A 00-10 0C 00 50 ¦IDATx^++- P 3700: FF FF 6F CA-8D B8 A8 95-92 1C 56 0E-36 9B F9 0E o-ì+¿òÆ V 6¢· ... 5CE0: EE 4B 05 D4-46 49 B3 66-30 ED 6E BF-E7 23 7B C9 eK +FI¦f0fn+t#{+ 5CF0: C8 D7 51 F8-99 B7 9C 00-00 00 00 49-45 4E 44 AE ++Q°Ö+£ IEND« 5D00: 42 60 82 00-00 00 00 00-00 00 00 00-00 00 00 00 B`é.............
  • 109. Generalized case The only requirements: ● The source format tolerates appended data ● The target format can fit a signature and chunk declaration in a single cipher block ● S fits in a single target format chunk We can use other algorithms, both ways (encryption or decryption) with various file formats (even in the same file)
  • 110. → PoC||GTFO 0x3 is a PDF that you can encrypt into a PNG (and it shows its own IV)
  • 111. For more information (PDF, JPG, GynCryption, PiP…): https://speakerdeck.com/ange/when-aes-equals-episode-v https://www.youtube.com/watch?v=wbHkVZfCNuE
  • 113. Let’s play with TrueCrypt
  • 114. TrueCrypt software ● Creates and manages a virtual storage volume ○ Encrypted ○ Transparent for the system The volume is useless without the password.
  • 115. ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ 6ìIDATX├∞┘╦z╙ ╪ α ►JFIF ☺☺☺ ┤ ┤ █ C ♠♦♣♠♣♦♠ ♠♣♠••♠◘◙►◙◙○○◙¶♫ ☼♀►↨¶↑↑↨¶▬▬→↔%▼→ ←#∟▬▬ , #&')*)↓▼ -0-(0%()( █ C☺•• •◙◘◙‼◙◙‼(→▬→(((( (((((((((((((((( %PDF-1.3◙%─σ≥σδº ≤á╨─╞◙4 0 obj◙<< /Length 5 0 R / Filter /FlateDec ode >>◙stream◙x☺ ⌂ELF☺☻☺♥ ☻ ¶ ☺ ▬:É 4 4 ☻ ( ☺ ► ► ♠K¼ ♠K¼ ♣ ☺ ☺ ∙Φ► ∙Φ ► ∙Φ ♠ ☺ ╣E)lUPX!↓◄♪ä ZIP JPG MZÉ ♥ ♦ ╕ @ ◘☺ ♫▼║♫ ┤○═!╕☺L═!Th is program canno t be run in DOS mode.♪♪◙$ PK♥♦¶ ◘ î◄|>á# SÇ≈♀ ♫∟ ↕ Cl ftypisom ☻ isomiso2avc1mp41 *freevideo se rved by mod_h264 _streaming ▲¿<mo ov lmvhd |% ░Ç|%░Ç ♥Φ ),( ☺ PE Standard file format headers
  • 116. d/Γ↨jôù☺♫Ö▲b¶n0ï ∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ► -◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+ m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦ ♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l ┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m' (7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~ ░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢ ▬£÷Cd▼├à·3g~Bêc┌ MΦvεÖ/à╕⌂Ñ9ôΓ≈♫╤ ┐╩P┴╥F¥0½╙'*"ú▌◙ ¡╔^è¼¶│ÅDN▌♀♂¬↨♠ !>τ╡⌐A!┬W`δÜp£]₧ Y≡yí#û?♥╞-î§yY¶╖ ○σï½Ü◙E¬"╫⌂2Θ♠╨6 ⌡ù@e7▲▬▌╒<╤TQTHΩ Ω╟╬ìPδW9▀8◄Σê♫╨Ω ♦♠Æ►♂r▬╜E╣&╚☻⌠¬░ πa ┐╪å<6▀vMR6₧☻: ♦: n┬F≡_τ╝╫╦≡m▌▬ ┬ô£Ç`☼Jl◘∞• ÿ╗≥∞ ╒[►y♠→↨Ñà╩t‼╫α┬Å J·¶ë├α♫╠◄Θi_╥I╗╗ ≤╟úKû•=┘╩☺§§.rΩP ≥↔?{♠àQ{╓◘≈┼╜╕|½ Q&f►∞Ü→▄σÖσû►↑¶4 ╜>e#TrÄ5 HòƒÑV▄║ ▬╤íΦDi╔)↑â←Ü─+┌∞ Kd(¢╚ñ╖¢MTac■▌l± é«Cñ─=¿N_↨N►♫φÅε ╔o╧Y1Z$Σ▬╨h╬a¥¼j ↓M¬┐Y#°h≡¿?σ┬♀c| ▀;P,→k;Q^▄x▓α▌½┬ │7e9"⌡ÆΦ╬▓ⁿD²#Ç▼ ═«↓⌐☻┐Σü╘∟¼î¼╟ùI è╖$Aσ♣²=ß>└▀K∩τì 0►n#ƒ☼ⁿs@ ♫0-X▀☼ ₧w,ΓòR☻ù♠○├ï☻s○x ±Σ.hƒ9◄▒5w♣☼⌠○▬â +ÑΣ≈↕▀┘τ╗ N¼ciâ% I╤l►éLóO8♣±Çs▀○↨ ☺╔i╪.~¶Ge╢Ög╗█÷* ‼Vö▀%.í÷# 3éÑûÇ♦ δ═├CμO*$M▲ç5{Z?φ τΦL├{╗ùΦ▲²÷═ⁿW╗P /¼◙^←[│╣¡ xÉμ1hF Headers of different TrueCrypt files.
  • 117. Random contents? A file format designed not to be identified ● except if you have the password ● random appearance ○ you can deny it’s a TrueCrypt volume ● there is a header ○ but it’s encrypted
  • 118. TRUE ♣• Iî$B É ☻ É ☻ C¬α╔Ñ «ÑêI█⌠▬♀D╣▼xΦm↓¬0τzP°W5» ╣FcJl¼∙L¢▒9Oä° τEpó&←╠¿oμÆ☺▬ìä5Θä↨_○¼I┐¡ ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L A TrueCrypt header, before and after decryption.
  • 119. How many files do you have that are 100% random? it’s not so stealthy
  • 120. Potential volumes detection ● no known header ● “big size” ● size rounded to 512 ● random content from the start ○ very high entropy
  • 121. Just a password? If encryption only depends on the password, TrueCrypt is vulnerable to rainbow * table attacks. * pre-computed tables (to make faster attacks)
  • 122. Salt The file starts with 64 bytes of salt: ● random data ● combined with the password ● used to decrypt the header ⇒ no possible pre-computing ⇒ rainbow tables are useless
  • 123. d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... Salt (to decrypt the header) Header ● crypted with salt and password ● contains the key used to decrypt the volume Volume ● encrypted with the key in the header Structure of a TrueCrypt volume
  • 124. If we modify the salt, we just have to to re-crypt the header no need to change the volume itself (the volume key hasn’t changed)
  • 125. Idea: Integrate a TrueCrypt volume into another file - stealthier - both formats stay valid
  • 126. Strategy 1. Modify the host to make free space near the beginning ○ create a custom chunk to contain the volume 2. Copy the header and the volume’s content ○ the decrypted header hasn’t changed, and the volume hasn’t either 3. Decrypt the header ○ with the initial salt 4. Re-crypt the header ○ with the salt from the start of the host 5. Adjust the CRC of the chunk ○ optional, as the chunk is ancillary
  • 127. ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ 6ìIDATX├∞┘╦z╙f☻╞q:¥C█òƒg:○ÿ►L τ♠╝₧Æáp╩njB╚üC►▌╡Ñ┼ä╬^wα←h►9┴∞|♣ Eí7α⌡äâÆmí╚w≡═√╔û-┘Æ¡ôc[~▀τ∙»║¬∞ ∩╦☼∙ö►Γ¶cî1╞╪ ΓC`î1╞╪`í1i¢yl)▓│e K│{dUæ!╦?▓jHtvμ'ºÅ₧N °╤Då½◙╥ª←)▓ S∟╟q∟7⌐╦24╬=╢◙¿ä4└┬@&↕N@FúGφ≥☺⌡Ç åo╙■↓╙☼ ╨æå¶öπ7Éπ8Ä#4╞d│¢⌡┬∞ªU♠, ¬╚D┬i╞º▬4B`#%h◘αó3│ëÅ≥╘├☼E~#9Äπ8 Bcäv~│^☻0*╚DBμ♠F/lDüF←←⌐Cú§á!ª~° `!↔⌐êo<8Äπ8Bc◘╕PÉļ≤Mx♂•ìx?ƒ♀∟→ ¥U%:■±=╤┴q▄Σφïτ▀ΩHx┌wzαm»G╗25|;≈ k|·‼♠ì┬ôz☺i╚ö╕p7Lh♦a#64ⁿ▒! ♪⌠╛èJ ⁿ╓r∟7◄╚x☺d╝ (:kíπü╖²▲┘αP╗≤çFφï↔ò ╕¢¶h ▬◙╥æpΩä╞∙‼àå5Lh8Y¿é◙ⁿ♠s∟ùI dⁿ7 ↓/:▐nñ☼ì→"2&☺→↨~«+╚p♥#<4Ω╛╨p a├D♠╥Ç♀Ö☻`┤╩•♦dáÅeñí◙2É↓ΘτôD╨≡`├ I╛σP°Mμ8.+√ⁿ┼╖:↕v╧♥┌wzαm/á]Ö┌▌ĺ ┌τ|ôæ}h|╒♦♠↕Nqá╤±Vúè44░?╚Çàé╩HGμ ○BC|∙¥¥ü◘♫Äπ▓âîôà♠ææuh ↑Ed|σ☻F►4 ⁿ░╤☺♪♂╨╨☺ï╥░■⌂Çè"*ú┌○Aâαα8n2ɱ< ↓±íAdd↓→ÇE♫Θ↕↑N○áQEÑQ{╞ Fíë♫≤♦áA pp∟7v√♀╚°∞┼♥ßΘy@√Njw{☺φ╩εw╖s┐åêî d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... TrueCrypt volume Image
  • 128. ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ ♦Å╫true d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... Create free space in the file to host the volume.
  • 129. d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ ♦Å╫true ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... ⇒ Copy the volume in the created space.
  • 130. d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ ♦Å╫true TRUE ♣• Iî$B É ☻ É ☻ C¬α╔Ñ«ÑêI█⌠▬♀D╣▼xΦm↓¬0τzP°W5»╣Fc Jl¼∙L¢▒9Oä°τEpó&←╠¿oμÆ☺▬ìä5Θä↨_○ ¼I┐¡ Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... Decrypt the header with the volume’s salt.
  • 131. d/Γ↨jôù☺♫Ö▲b¶n0ï∟RKl♣╟┐l⌂QH┐▐φ♫ö ┬_φ┬Ió£ná→╖G∙♣Σ►-◄8╓ZX◙nb¶ìMÇx▄Ö ╟ü╪Gñö◙-•╢É}►f~+m←↓ü;·$¿4σ╫áú≈₧ U'k~ù^▒H▄s₧╦êΘμ♦♠╔,Gδ;åa┤∙NßWπsδ »Mπ◄=┌G]t +ßQ^l┴mí≡èτDz╜&╜⌠╨SOî Vg£ª}ù↓¢┘;4Γ╖á♠┘ñ▼ö►:♂╠L♦9♂╚╢ÆH( ô ª╛‼ß±ùH»S╪g)m'(7☻òá╡L'6G☺ÖÇ♠"î üLδ░╣»e╧¬ç╒"∞òα~░§§É↑â╜ærâp╥xε▲♣ ┌Uü╜╫l╪Ñ≥ôùRc∙╠Γ¡öàx₧╢₧╚f▌Z┘é♪!Ω L◄±Ä3╬╤ε}:ÇRu╒º¢=2ñ∩╝·└¬╝╣♀║æ╘Q╔ Aüμ{w{y◙ƃom¥↕ú±╣}k▄0○◄↑Ä╪┌&D?í√ ╒Z█ jαÆ╙ë{/╗αô.*R←pr(b?▼◄&åÆ▲Θ[É bÆμA▲ºßÑ∟Θ▀döòêî♪Ω&yá╔☼◘┌╧>▲╓M1* ╦*¡∟☺4Å)▼ôTαÉ÷↔+◙‼M« :▼GF[($nΘ÷Å ▌╣èTΦ▲Sσ■ëOì#÷ô]+◄:f9ôτu╓█B▒♦▬█↕ ♫╪(Z⌡▬ñ[< G]≡ÇâΦ╗⌂█∟⌠í<|æ9oΣ║z!L Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ ♦Å╫true ┤♣▒εÜ┘$φ╗3☼»αG↔öÇ═0₧:P╞!•▒áwó░« u∟╔AL╙J<►Φs L╣I▌èαè3l?WÑû╠♠ìΣ}⌂ n°ôaîlö§╔ó¢i∞¬∩╦8≡)≤Çg╘╩┴3ëΓ%◄/( b☻▬↔‼⌐j☻♥dæ╧↔ä♪┘┬ì §(▒┌:╞ùxº╟║∞◄ á◄űn≤ó± ►¶Jp/♀α/♠P☼zz(≤ÿ╩↔ï┼§•ô ,∟+╙aμ─CΩ⌐‼÷α░s╕Å':òφw≡O»♀1▓z♣&ñ y╔╕à"IX≤▄ⁿJ♣║PÑnö¿╣τ┴7à&ªü>¬ï║Wx w^╚>à►mtûσf√•wâ╗╥²┼xÿáôùε▄ôτô≤█≥ ╩┌Aj≤⌐¢╟╬M┬ûí δτ╩~⌐Pl¶¼┌╢!zWÅuδ$ /≥Ñw╒V♀WR┤V╥°╔═√=¼7°²√▲┼kd√Fösùc █◘k├o¬åù♂r╢§F╙◘≥|MÖP;@∞↑xäεù→æ½ r♦«▐R≥óå2♦ô&═τ'5$¼♫π╥÷èzef¥Uí`∙j ╪'¬├Rö`ÿ¶óB≤╪2⌠↑RmâÖ▐¡╝→‼pò[│k«╗ å;·L→pÜ│bzÖ=b¬S~û|¶¿î╩G╢ç╖¼ ‼«ö♠ Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... Encrypt the header with the salt from the host.
  • 132. ëPNG♪◙→◙ ♪IHDR ☻→ ╛◘♠ s½ª ≈ ♦Å╫true ┤♣▒εÜ┘$φ╗3☼»αG↔öÇ═0₧:P╞!•▒áwó░« u∟╔AL╙J<►Φs L╣I▌èαè3l?WÑû╠♠ìΣ}⌂ n°ôaîlö§╔ó¢i∞¬∩╦8≡)≤Çg╘╩┴3ëΓ%◄/( b☻▬↔‼⌐j☻♥dæ╧↔ä♪┘┬ì §(▒┌:╞ùxº╟║∞◄ á◄űn≤ó± ►¶Jp/♀α/♠P☼zz(≤ÿ╩↔ï┼§•ô ,∟+╙aμ─CΩ⌐‼÷α░s╕Å':òφw≡O»♀1▓z♣&ñ y╔╕à"IX≤▄ⁿJ♣║PÑnö¿╣τ┴7à&ªü>¬ï║Wx w^╚>à►mtûσf√•wâ╗╥²┼xÿáôùε▄ôτô≤█≥ ╩┌Aj≤⌐¢╟╬M┬ûí δτ╩~⌐Pl¶¼┌╢!zWÅuδ$ /≥Ñw╒V♀WR┤V╥°╔═√=¼7°²√▲┼kd√Fösùc █◘k├o¬åù♂r╢§F╙◘≥|MÖP;@∞↑xäεù→æ½ r♦«▐R≥óå2♦ô&═τ'5$¼♫π╥÷èzef¥Uí`∙j ╪'¬├Rö`ÿ¶óB≤╪2⌠↑RmâÖ▐¡╝→‼pò[│k«╗ å;·L→pÜ│bzÖ=b¬S~û|¶¿î╩G╢ç╖¼ ‼«ö♠ Ö╚Sâìí°B'⌡♪♀┬Q1■#┐[∟█╝╜x│I╨♦┌½c╪ ▬è▄UYÆ/º·╝☻0£MP╔ê¿J♪_>╡∟╢εVRt╣i ª÷┘FÆ╬C╕μïc┘$☺ƒc»-7JÅï○})ªj♪σ+Θê ↑(Ä╔•é░u_─◙Xm½8▬╫á≤≥╗▬à<↑GÄ≈4G߬ ↑μ^═Γu╩úC┐☻╟iÆ▀Ñ»FS∟≥■♂╕WCÑ╨ê±²ñ äδ:ºék╡nÄw╩߯▬!z∞♫ N½Φ╒┼C◘╬ÑÑ ?D ... Sal TrueCrypt PNG Header Volume’s content End of volume Image (ignored) Signature + header Chunk declaration Chunk data Chunk end Original chunks
  • 133. TrueCrypt volumes in standard files (still useable and modifiable)
  • 134. Conclusion 1/2 ● We can add extra data in a standard binary file ● This data can be: ○ another standard file, after en/decryption ○ a TrueCrypt volume
  • 135. Conclusion 2/2 ● No need to understand everything to have fun with crypto ● Better progress step by step ○ ask an expert ○ hard to debug ● Encrypted doesn’t mean random ● examples: http://bit.ly/1n63yKP (http://corkami.googlecode.com/svn/trunk/src/angecryption/rmll)
  • 136. Acknowledgments @veorq @doegox @iamreddave @miaubiz @travisgoodspeed @sergeybratus @cynicalsecurity @rantyben @thegrugq @skier_t @jvanegue @kaepora @munin @joernchen @andreasdotorg @tabascoeye @cryptax @pinkflawd @push_pnx @gynvael @rfidiot @cbrocas @kennwhite...
  • 137. @angealbertini corkami.com Damn, that's the second time those alien bastards shot up my ride!