xref: /aosp_15_r20/external/mesa3d/src/panfrost/compiler/valhall/test-assembly.py (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker#encoding=utf-8
2*61046927SAndroid Build Coastguard Worker
3*61046927SAndroid Build Coastguard Worker# Copyright (C) 2020 Collabora, Ltd.
4*61046927SAndroid Build Coastguard Worker#
5*61046927SAndroid Build Coastguard Worker# Permission is hereby granted, free of charge, to any person obtaining a
6*61046927SAndroid Build Coastguard Worker# copy of this software and associated documentation files (the "Software"),
7*61046927SAndroid Build Coastguard Worker# to deal in the Software without restriction, including without limitation
8*61046927SAndroid Build Coastguard Worker# the rights to use, copy, modify, merge, publish, distribute, sublicense,
9*61046927SAndroid Build Coastguard Worker# and/or sell copies of the Software, and to permit persons to whom the
10*61046927SAndroid Build Coastguard Worker# Software is furnished to do so, subject to the following conditions:
11*61046927SAndroid Build Coastguard Worker#
12*61046927SAndroid Build Coastguard Worker# The above copyright notice and this permission notice (including the next
13*61046927SAndroid Build Coastguard Worker# paragraph) shall be included in all copies or substantial portions of the
14*61046927SAndroid Build Coastguard Worker# Software.
15*61046927SAndroid Build Coastguard Worker#
16*61046927SAndroid Build Coastguard Worker# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*61046927SAndroid Build Coastguard Worker# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*61046927SAndroid Build Coastguard Worker# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19*61046927SAndroid Build Coastguard Worker# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*61046927SAndroid Build Coastguard Worker# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*61046927SAndroid Build Coastguard Worker# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22*61046927SAndroid Build Coastguard Worker# IN THE SOFTWARE.
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Workerfrom asm import parse_asm, ParseError
25*61046927SAndroid Build Coastguard Workerimport sys
26*61046927SAndroid Build Coastguard Workerimport struct
27*61046927SAndroid Build Coastguard Worker
28*61046927SAndroid Build Coastguard Workerdef parse_hex_8(s):
29*61046927SAndroid Build Coastguard Worker    b = [int(x, base=16) for x in s.split(' ')]
30*61046927SAndroid Build Coastguard Worker    return sum([x << (8 * i) for i, x in enumerate(b)])
31*61046927SAndroid Build Coastguard Worker
32*61046927SAndroid Build Coastguard Workerdef hex_8(u64):
33*61046927SAndroid Build Coastguard Worker    as_bytes = struct.pack('<Q', u64)
34*61046927SAndroid Build Coastguard Worker    as_strings = [('0' + hex(byte)[2:])[-2:] for byte in as_bytes]
35*61046927SAndroid Build Coastguard Worker    return ' '.join(as_strings)
36*61046927SAndroid Build Coastguard Worker
37*61046927SAndroid Build Coastguard Worker# These should not throw exceptions
38*61046927SAndroid Build Coastguard Workerdef positive_test(machine, assembly):
39*61046927SAndroid Build Coastguard Worker    try:
40*61046927SAndroid Build Coastguard Worker        expected = parse_hex_8(machine)
41*61046927SAndroid Build Coastguard Worker        val = parse_asm(assembly)
42*61046927SAndroid Build Coastguard Worker        if val != expected:
43*61046927SAndroid Build Coastguard Worker            return f"{hex_8(val)}    Incorrect assembly"
44*61046927SAndroid Build Coastguard Worker    except ParseError as exc:
45*61046927SAndroid Build Coastguard Worker        return f"Unexpected exception: {exc}"
46*61046927SAndroid Build Coastguard Worker
47*61046927SAndroid Build Coastguard Worker# These should throw exceptions
48*61046927SAndroid Build Coastguard Workerdef negative_test(assembly):
49*61046927SAndroid Build Coastguard Worker    try:
50*61046927SAndroid Build Coastguard Worker        parse_asm(assembly)
51*61046927SAndroid Build Coastguard Worker        return "Expected exception"
52*61046927SAndroid Build Coastguard Worker    except Exception:
53*61046927SAndroid Build Coastguard Worker        return None
54*61046927SAndroid Build Coastguard Worker
55*61046927SAndroid Build Coastguard WorkerPASS = []
56*61046927SAndroid Build Coastguard WorkerFAIL = []
57*61046927SAndroid Build Coastguard Worker
58*61046927SAndroid Build Coastguard Workerdef record_case(case, error):
59*61046927SAndroid Build Coastguard Worker    if error is None:
60*61046927SAndroid Build Coastguard Worker        PASS.append(case)
61*61046927SAndroid Build Coastguard Worker    else:
62*61046927SAndroid Build Coastguard Worker        FAIL.append((case, error))
63*61046927SAndroid Build Coastguard Worker
64*61046927SAndroid Build Coastguard Workerif len(sys.argv) < 3:
65*61046927SAndroid Build Coastguard Worker    print("Expected positive and negative case lists")
66*61046927SAndroid Build Coastguard Worker    sys.exit(1)
67*61046927SAndroid Build Coastguard Worker
68*61046927SAndroid Build Coastguard Workerwith open(sys.argv[1], "r") as f:
69*61046927SAndroid Build Coastguard Worker    cases = f.read().split('\n')
70*61046927SAndroid Build Coastguard Worker    cases = [x for x in cases if len(x) > 0 and x[0] != '#']
71*61046927SAndroid Build Coastguard Worker
72*61046927SAndroid Build Coastguard Worker    for case in cases:
73*61046927SAndroid Build Coastguard Worker        (machine, assembly) = case.split('    ')
74*61046927SAndroid Build Coastguard Worker        record_case(case, positive_test(machine, assembly))
75*61046927SAndroid Build Coastguard Worker
76*61046927SAndroid Build Coastguard Workerwith open(sys.argv[2], "r") as f:
77*61046927SAndroid Build Coastguard Worker    cases = f.read().split('\n')
78*61046927SAndroid Build Coastguard Worker    cases = [x for x in cases if len(x) > 0]
79*61046927SAndroid Build Coastguard Worker
80*61046927SAndroid Build Coastguard Worker    for case in cases:
81*61046927SAndroid Build Coastguard Worker        record_case(case, negative_test(case))
82*61046927SAndroid Build Coastguard Worker
83*61046927SAndroid Build Coastguard Workerprint("Passed {}/{} tests.".format(len(PASS), len(PASS) + len(FAIL)))
84*61046927SAndroid Build Coastguard Worker
85*61046927SAndroid Build Coastguard Workerif len(FAIL) > 0:
86*61046927SAndroid Build Coastguard Worker    print("Failures:")
87*61046927SAndroid Build Coastguard Worker    for (fail, err) in FAIL:
88*61046927SAndroid Build Coastguard Worker        print("")
89*61046927SAndroid Build Coastguard Worker        print(fail)
90*61046927SAndroid Build Coastguard Worker        print(err)
91*61046927SAndroid Build Coastguard Worker    sys.exit(1)
92