17ec681f3Smrg/* 27ec681f3Smrg * Copyright (C) 2019 Connor Abbott <cwabbott0@gmail.com> 37ec681f3Smrg * Copyright (C) 2019 Lyude Paul <thatslyude@gmail.com> 47ec681f3Smrg * Copyright (C) 2019 Ryan Houdek <Sonicadvance1@gmail.com> 57ec681f3Smrg * Copyright (C) 2019-2020 Collabora, Ltd. 67ec681f3Smrg * 77ec681f3Smrg * Permission is hereby granted, free of charge, to any person obtaining a 87ec681f3Smrg * copy of this software and associated documentation files (the "Software"), 97ec681f3Smrg * to deal in the Software without restriction, including without limitation 107ec681f3Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 117ec681f3Smrg * and/or sell copies of the Software, and to permit persons to whom the 127ec681f3Smrg * Software is furnished to do so, subject to the following conditions: 137ec681f3Smrg * 147ec681f3Smrg * The above copyright notice and this permission notice (including the next 157ec681f3Smrg * paragraph) shall be included in all copies or substantial portions of the 167ec681f3Smrg * Software. 177ec681f3Smrg * 187ec681f3Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 197ec681f3Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 207ec681f3Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 217ec681f3Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 227ec681f3Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 237ec681f3Smrg * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 247ec681f3Smrg * SOFTWARE. 257ec681f3Smrg */ 267ec681f3Smrg 277ec681f3Smrg/* Prints shared with the disassembler */ 287ec681f3Smrg 297ec681f3Smrg#include "bi_print_common.h" 307ec681f3Smrg 317ec681f3Smrgconst char * 327ec681f3Smrgbi_message_type_name(enum bifrost_message_type T) 337ec681f3Smrg{ 347ec681f3Smrg switch (T) { 357ec681f3Smrg case BIFROST_MESSAGE_NONE: return ""; 367ec681f3Smrg case BIFROST_MESSAGE_VARYING: return "vary"; 377ec681f3Smrg case BIFROST_MESSAGE_ATTRIBUTE: return "attr"; 387ec681f3Smrg case BIFROST_MESSAGE_TEX: return "tex"; 397ec681f3Smrg case BIFROST_MESSAGE_VARTEX: return "vartex"; 407ec681f3Smrg case BIFROST_MESSAGE_LOAD: return "load"; 417ec681f3Smrg case BIFROST_MESSAGE_STORE: return "store"; 427ec681f3Smrg case BIFROST_MESSAGE_ATOMIC: return "atomic"; 437ec681f3Smrg case BIFROST_MESSAGE_BARRIER: return "barrier"; 447ec681f3Smrg case BIFROST_MESSAGE_BLEND: return "blend"; 457ec681f3Smrg case BIFROST_MESSAGE_TILE: return "tile"; 467ec681f3Smrg case BIFROST_MESSAGE_Z_STENCIL: return "z_stencil"; 477ec681f3Smrg case BIFROST_MESSAGE_ATEST: return "atest"; 487ec681f3Smrg case BIFROST_MESSAGE_JOB: return "job"; 497ec681f3Smrg case BIFROST_MESSAGE_64BIT: return "64"; 507ec681f3Smrg default: return "XXX reserved"; 517ec681f3Smrg } 527ec681f3Smrg} 537ec681f3Smrg 547ec681f3Smrgconst char * 557ec681f3Smrgbi_flow_control_name(enum bifrost_flow mode) 567ec681f3Smrg{ 577ec681f3Smrg switch (mode) { 587ec681f3Smrg case BIFROST_FLOW_END: return "eos"; 597ec681f3Smrg case BIFROST_FLOW_NBTB_PC: return "nbb br_pc"; 607ec681f3Smrg case BIFROST_FLOW_NBTB_UNCONDITIONAL: return "nbb r_uncond"; 617ec681f3Smrg case BIFROST_FLOW_NBTB: return "nbb"; 627ec681f3Smrg case BIFROST_FLOW_BTB_UNCONDITIONAL: return "bb r_uncond"; 637ec681f3Smrg case BIFROST_FLOW_BTB_NONE: return "bb"; 647ec681f3Smrg case BIFROST_FLOW_WE_UNCONDITIONAL: return "we r_uncond"; 657ec681f3Smrg case BIFROST_FLOW_WE: return "we"; 667ec681f3Smrg default: return "XXX"; 677ec681f3Smrg } 687ec681f3Smrg} 69