Commit | Line | Data |
---|---|---|
9726711d MD |
1 | #!/usr/bin/env python3 |
2 | ||
3 | # Expects either "prepare" or "clean" argument | |
4 | ||
5 | import sys | |
6 | import os | |
7 | ||
8 | def arg_err(): | |
9 | print('Please specify "prepare <SIZE>" or "clean <SIZE>" as first argument.') | |
10 | sys.exit(-1) | |
11 | ||
12 | if (len(sys.argv) <= 1): | |
13 | arg_err() | |
14 | mode = sys.argv[1] | |
15 | if (len(sys.argv) <= 2): | |
16 | arg_err() | |
17 | array_len = int(sys.argv[2]) | |
18 | ||
19 | tracedir_name = './trace-' + str(array_len) + '/' | |
20 | output_metadata = tracedir_name + 'metadata' | |
21 | output_stream = tracedir_name + 'stream' | |
22 | ||
23 | ||
24 | def write_binary(f, arr): | |
25 | f.write(bytes(arr)) | |
26 | ||
27 | def generate_metadata(array_len): | |
28 | # Generate metadata | |
29 | metadata_str1 = \ | |
30 | ( '/* CTF 1.8 */\n' | |
31 | '\n' | |
32 | 'typealias integer {{ size = 8; align = 8; signed = false; base = 10; }} := uint8_t;\n' | |
33 | 'typealias integer {{ size = 32; align = 32; signed = false; base = hex; }} := uint32_t;\n' | |
34 | '\n' | |
35 | 'trace {{\n' | |
83fcdab0 FD |
36 | ' major = 1;\n' |
37 | ' minor = 8;\n' | |
9726711d MD |
38 | ' uuid = "2a6422d0-6cee-11e0-8c08-cb07d7b3a564";\n' |
39 | ' byte_order = le;\n' | |
40 | ' packet.header := struct {{\n' | |
41 | ' uint32_t magic;\n' | |
42 | ' uint8_t uuid[16];\n' | |
43 | ' }};\n' | |
44 | '}};\n' | |
45 | '\n' | |
46 | 'event {{\n' | |
47 | ' name = myevent;\n' | |
48 | ' fields := struct {{\n').format() | |
49 | ||
50 | metadata_nest_push = \ | |
51 | ' struct {{\n' | |
52 | ||
53 | metadata_str2 = \ | |
54 | ( ' uint8_t field; \n').format() | |
55 | ||
56 | metadata_nest_pop = \ | |
57 | ' }} s_depth_{};\n' | |
58 | ||
59 | metadata_str3 = \ | |
60 | ( ' }};\n' | |
61 | '}};\n').format() | |
62 | metadata_f = open(output_metadata, 'w') | |
63 | metadata_f.write(metadata_str1) | |
64 | for i in range(array_len): | |
65 | metadata_f.write(metadata_nest_push.format()) | |
66 | metadata_f.write(metadata_str2) | |
67 | for i in range(array_len): | |
68 | metadata_f.write(metadata_nest_pop.format(i)) | |
69 | metadata_f.write(metadata_str3) | |
70 | metadata_f.close() | |
71 | ||
72 | def generate_stream(array_len): | |
73 | # Generate stream | |
74 | stream_packet_header = [ | |
75 | 0xC1, 0x1F, 0xFC, 0xC1, # magic | |
76 | 0x2A, 0x64, 0x22, 0xD0, 0x6C, 0xEE, 0x11, 0xE0, | |
77 | 0x8C, 0x08, 0xCB, 0x07, 0xD7, 0xB3, 0xA5, 0x64, # uuid | |
78 | ] | |
79 | stream_f = open(output_stream, 'wb') | |
80 | write_binary(stream_f, stream_packet_header) | |
81 | # generate single byte event as event content | |
82 | os.ftruncate(stream_f.fileno(), len(stream_packet_header) + 1) | |
83 | stream_f.close() | |
84 | ||
85 | def test_prepare(): | |
86 | print('Preparing test for deeply nested structure ' + str(array_len) + ' levels') | |
87 | os.mkdir(tracedir_name) | |
88 | generate_metadata(array_len) | |
89 | generate_stream(array_len) | |
90 | ||
91 | def test_clean(): | |
92 | print('Cleaning up test for deeply nested structure ' + str(array_len) + ' levels') | |
93 | try: | |
94 | os.remove(output_metadata) | |
95 | except: | |
96 | pass | |
97 | try: | |
98 | os.remove(output_stream) | |
99 | except: | |
100 | pass | |
101 | try: | |
102 | os.rmdir(tracedir_name) | |
103 | except: | |
104 | pass | |
105 | ||
106 | if (mode == "prepare"): | |
107 | test_clean() | |
108 | test_prepare() | |
109 | elif (mode == "clean"): | |
110 | test_clean() | |
111 | else: | |
112 | arg_err() |