17ec681f3Smrgtemplate = """/* 27ec681f3Smrg * Copyright (C) 2021 Alyssa Rosenzweig <alyssa@rosenzweig.io> 37ec681f3Smrg * 47ec681f3Smrg * Permission is hereby granted, free of charge, to any person obtaining a 57ec681f3Smrg * copy of this software and associated documentation files (the "Software"), 67ec681f3Smrg * to deal in the Software without restriction, including without limitation 77ec681f3Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 87ec681f3Smrg * and/or sell copies of the Software, and to permit persons to whom the 97ec681f3Smrg * Software is furnished to do so, subject to the following conditions: 107ec681f3Smrg * 117ec681f3Smrg * The above copyright notice and this permission notice (including the next 127ec681f3Smrg * paragraph) shall be included in all copies or substantial portions of the 137ec681f3Smrg * Software. 147ec681f3Smrg * 157ec681f3Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 167ec681f3Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 177ec681f3Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 187ec681f3Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 197ec681f3Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 207ec681f3Smrg * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 217ec681f3Smrg * SOFTWARE. 227ec681f3Smrg */ 237ec681f3Smrg 247ec681f3Smrg#include "agx_opcodes.h" 257ec681f3Smrg 267ec681f3Smrg<% 277ec681f3Smrgdef make_encoding(encoding): 287ec681f3Smrg if encoding is None: 297ec681f3Smrg return "{ 0 }" 307ec681f3Smrg 317ec681f3Smrg return "{{ {}, {}, {} }}".format(hex(encoding.exact), encoding.length_short, int(encoding.extensible)) 327ec681f3Smrg%> 337ec681f3Smrg 347ec681f3Smrgconst struct agx_opcode_info agx_opcodes_info[AGX_NUM_OPCODES] = { 357ec681f3Smrg% for opcode in opcodes: 367ec681f3Smrg<% 377ec681f3Smrg op = opcodes[opcode] 387ec681f3Smrg imms = ["AGX_IMMEDIATE_" + imm.name.upper() for imm in op.imms] 397ec681f3Smrg if len(imms) == 0: 407ec681f3Smrg imms = ["0"] 417ec681f3Smrg%> 427ec681f3Smrg [AGX_OPCODE_${opcode.upper()}] = { 437ec681f3Smrg "${opcode}", ${op.srcs}, ${op.dests}, ${" | ".join(imms)}, 447ec681f3Smrg ${make_encoding(op.encoding_32)}, 457ec681f3Smrg ${make_encoding(op.encoding_16)}, 467ec681f3Smrg ${int(op.is_float)}, 477ec681f3Smrg ${int(op.can_eliminate)}, 487ec681f3Smrg }, 497ec681f3Smrg% endfor 507ec681f3Smrg}; 517ec681f3Smrg""" 527ec681f3Smrg 537ec681f3Smrgfrom mako.template import Template 547ec681f3Smrgfrom agx_opcodes import opcodes 557ec681f3Smrg 567ec681f3Smrgprint(Template(template).render(opcodes=opcodes)) 57