1template = """/*
2 * Copyright (C) 2021 Alyssa Rosenzweig <alyssa@rosenzweig.io>
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
13 * Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 * SOFTWARE.
22 */
23
24#include "agx_opcodes.h"
25
26<%
27def make_encoding(encoding):
28   if encoding is None:
29      return "{ 0 }"
30
31   return "{{ {}, {}, {} }}".format(hex(encoding.exact), encoding.length_short, int(encoding.extensible))
32%>
33
34const struct agx_opcode_info agx_opcodes_info[AGX_NUM_OPCODES] = {
35% for opcode in opcodes:
36<%
37   op = opcodes[opcode]
38   imms = ["AGX_IMMEDIATE_" + imm.name.upper() for imm in op.imms]
39   if len(imms) == 0:
40      imms = ["0"]
41%>
42   [AGX_OPCODE_${opcode.upper()}] = {
43      "${opcode}", ${op.srcs}, ${op.dests}, ${" | ".join(imms)},
44      ${make_encoding(op.encoding_32)},
45      ${make_encoding(op.encoding_16)},
46      ${int(op.is_float)},
47      ${int(op.can_eliminate)},
48   },
49% endfor
50};
51"""
52
53from mako.template import Template
54from agx_opcodes import opcodes
55
56print(Template(template).render(opcodes=opcodes))
57