orbital/tests/test_gcn_disasm.c
Alexandro Sanchez Bach ef3601bf02
Added GCN analyzer/translator tests
Signed-off-by: Alexandro Sanchez Bach <alexandro@phi.nz>
2019-01-25 18:18:42 +01:00

62 lines
1.4 KiB
C

/**
* (c) 2019 Alexandro Sanchez Bach. All rights reserved.
* Released under MIT license. Read LICENSE for more details.
*/
#include "gcn_disasm.h"
#include "gcn_parser.h"
#include <stdio.h>
#include <stdlib.h>
#define UNUSED(arg) (void)(arg)
static int disasm_shader(const uint8_t *data, size_t size)
{
UNUSED(size);
gcn_parser_t parser;
gcn_disasm_t disasm;
gcn_parser_init(&parser);
gcn_disasm_init(&disasm);
gcn_parser_parse(&parser, data, &gcn_disasm_callbacks, &disasm);
return 0;
}
int main(int argc, const char **argv)
{
size_t shader_size;
uint8_t *shader_data;
const char *name;
FILE *file;
int ret;
if (argc <= 1) {
fprintf(stderr, "Usage: %s [path/to/shader.bin]\n", argv[0]);
return 0;
}
name = argv[1];
file = fopen(name, "rb");
if (!file) {
fprintf(stderr, "File %s does not exist!\n", name);
return 1;
}
fseek(file, 0, SEEK_END);
shader_size = ftell(file);
shader_data = malloc(shader_size);
if (!shader_data) {
fprintf(stderr, "Could not allocate 0x%zX bytes!\n", shader_size);
return 1;
}
fseek(file, 0, SEEK_SET);
if (fread(shader_data, 1, shader_size, file) != shader_size) {
fprintf(stderr, "Could not read 0x%zX bytes!\n", shader_size);
return 1;
}
ret = disasm_shader(shader_data, shader_size);
free(shader_data);
fclose(file);
return ret;
}