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#ifndef _AGX_OPCODES_ 257ec681f3Smrg#define _AGX_OPCODES_ 267ec681f3Smrg 277ec681f3Smrg#include <stdbool.h> 287ec681f3Smrg#include <stdint.h> 297ec681f3Smrg 307ec681f3Smrg/* Listing of opcodes */ 317ec681f3Smrg 327ec681f3Smrgenum agx_opcode { 337ec681f3Smrg% for op in opcodes: 347ec681f3Smrg AGX_OPCODE_${op.upper()}, 357ec681f3Smrg% endfor 367ec681f3Smrg AGX_NUM_OPCODES 377ec681f3Smrg}; 387ec681f3Smrg 397ec681f3Smrg% for name in enums: 407ec681f3Smrgenum agx_${name} { 417ec681f3Smrg% for k in enums[name]: 427ec681f3Smrg AGX_${name.upper()}_${enums[name][k].replace('.', '_').upper()} = ${k}, 437ec681f3Smrg% endfor 447ec681f3Smrg}; 457ec681f3Smrg% endfor 467ec681f3Smrg 477ec681f3Smrg/* Runtime accessible info on each defined opcode */ 487ec681f3Smrg 497ec681f3Smrg<% assert(len(immediates) < 32); %> 507ec681f3Smrg 517ec681f3Smrgenum agx_immediate { 527ec681f3Smrg% for i, imm in enumerate(immediates): 537ec681f3Smrg AGX_IMMEDIATE_${imm.upper()} = (1 << ${i}), 547ec681f3Smrg% endfor 557ec681f3Smrg}; 567ec681f3Smrg 577ec681f3Smrgstruct agx_encoding { 587ec681f3Smrg uint64_t exact; 597ec681f3Smrg unsigned length_short : 4; 607ec681f3Smrg bool extensible : 1; 617ec681f3Smrg}; 627ec681f3Smrg 637ec681f3Smrgstruct agx_opcode_info { 647ec681f3Smrg const char *name; 657ec681f3Smrg unsigned nr_srcs; 667ec681f3Smrg unsigned nr_dests; 677ec681f3Smrg enum agx_immediate immediates; 687ec681f3Smrg struct agx_encoding encoding; 697ec681f3Smrg struct agx_encoding encoding_16; 707ec681f3Smrg bool is_float : 1; 717ec681f3Smrg bool can_eliminate : 1; 727ec681f3Smrg}; 737ec681f3Smrg 747ec681f3Smrgextern const struct agx_opcode_info agx_opcodes_info[AGX_NUM_OPCODES]; 757ec681f3Smrg 767ec681f3Smrg#endif 777ec681f3Smrg""" 787ec681f3Smrg 797ec681f3Smrgfrom mako.template import Template 807ec681f3Smrgfrom agx_opcodes import opcodes, immediates, enums 817ec681f3Smrg 827ec681f3Smrgprint(Template(template).render(opcodes=opcodes, immediates=immediates, 837ec681f3Smrg enums=enums)) 84