Refactor assembler to use prog_t structure
Set the program structure correctly with a header using the parsed global instruction.
This commit is contained in:
17
asm/main.c
17
asm/main.c
@@ -88,9 +88,8 @@ int main(int argc, char *argv[])
|
|||||||
#if VERBOSE >= 2
|
#if VERBOSE >= 2
|
||||||
printf("\t[%sPARSER%s]: Beginning parse...\n", TERM_YELLOW, TERM_RESET);
|
printf("\t[%sPARSER%s]: Beginning parse...\n", TERM_YELLOW, TERM_RESET);
|
||||||
#endif
|
#endif
|
||||||
size_t number = 0;
|
prog_t *program = NULL;
|
||||||
inst_t *instructions = NULL;
|
perr_t parse_error = parse_stream(&tokens, &program);
|
||||||
perr_t parse_error = parse_stream(&tokens, &instructions, &number);
|
|
||||||
if (parse_error)
|
if (parse_error)
|
||||||
{
|
{
|
||||||
size_t column = 0;
|
size_t column = 0;
|
||||||
@@ -108,21 +107,21 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
#if VERBOSE >= 1
|
#if VERBOSE >= 1
|
||||||
printf("\t[%sPARSER%s]: %lu tokens -> %lu instructions\n", TERM_GREEN,
|
printf("\t[%sPARSER%s]: %lu tokens -> %lu instructions\n", TERM_GREEN,
|
||||||
TERM_RESET, tokens.available, number);
|
TERM_RESET, tokens.available, program->count);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if VERBOSE >= 2
|
#if VERBOSE >= 2
|
||||||
printf("\t[%sPARSER%s]: Instructions parsed:\n", TERM_GREEN, TERM_RESET);
|
printf("\t[%sPARSER%s]: Instructions parsed:\n", TERM_GREEN, TERM_RESET);
|
||||||
for (size_t i = 0; i < number; ++i)
|
for (size_t i = 0; i < program->count; ++i)
|
||||||
{
|
{
|
||||||
printf("\t[%lu]: ", i);
|
printf("\t[%lu]: ", i);
|
||||||
inst_print(instructions[i], stdout);
|
inst_print(program->instructions[i], stdout);
|
||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fp = fopen(out_file, "wb");
|
fp = fopen(out_file, "wb");
|
||||||
insts_write_bytecode_file(instructions, number, fp);
|
prog_write_file(program, fp);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
#if VERBOSE >= 1
|
#if VERBOSE >= 1
|
||||||
printf("[%sASSEMBLER%s]: Wrote bytecode to `%s`\n", TERM_GREEN, TERM_RESET,
|
printf("[%sASSEMBLER%s]: Wrote bytecode to `%s`\n", TERM_GREEN, TERM_RESET,
|
||||||
@@ -137,7 +136,7 @@ end:
|
|||||||
free(TOKEN_STREAM_AT(tokens.data, i).str);
|
free(TOKEN_STREAM_AT(tokens.data, i).str);
|
||||||
free(tokens.data);
|
free(tokens.data);
|
||||||
}
|
}
|
||||||
if (instructions)
|
if (program)
|
||||||
free(instructions);
|
free(program);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|||||||
36
asm/parser.c
36
asm/parser.c
@@ -477,7 +477,7 @@ label_t search_labels(label_t *labels, size_t n, char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
perr_t process_presults(presult_t *results, size_t res_count,
|
perr_t process_presults(presult_t *results, size_t res_count,
|
||||||
inst_t **instructions, size_t *inst_count)
|
prog_t **program_ptr)
|
||||||
{
|
{
|
||||||
#if VERBOSE >= 2
|
#if VERBOSE >= 2
|
||||||
printf("[%sprocess_presults%s]: Results found\n", TERM_YELLOW, TERM_RESET);
|
printf("[%sprocess_presults%s]: Results found\n", TERM_YELLOW, TERM_RESET);
|
||||||
@@ -515,7 +515,7 @@ perr_t process_presults(presult_t *results, size_t res_count,
|
|||||||
|
|
||||||
darr_t label_registry = {0};
|
darr_t label_registry = {0};
|
||||||
darr_init(&label_registry, sizeof(label_t));
|
darr_init(&label_registry, sizeof(label_t));
|
||||||
*inst_count = 0;
|
word inst_count = 0;
|
||||||
for (size_t i = 0; i < res_count; ++i)
|
for (size_t i = 0; i < res_count; ++i)
|
||||||
{
|
{
|
||||||
presult_t res = results[i];
|
presult_t res = results[i];
|
||||||
@@ -524,19 +524,19 @@ perr_t process_presults(presult_t *results, size_t res_count,
|
|||||||
case PRES_LABEL: {
|
case PRES_LABEL: {
|
||||||
label_t label = {.name = res.label,
|
label_t label = {.name = res.label,
|
||||||
.name_size = strlen(res.label),
|
.name_size = strlen(res.label),
|
||||||
.addr = (*inst_count) + 1};
|
.addr = inst_count + 1};
|
||||||
darr_append_bytes(&label_registry, (byte *)&label, sizeof(label));
|
darr_append_bytes(&label_registry, (byte *)&label, sizeof(label));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case PRES_RELATIVE_ADDRESS: {
|
case PRES_RELATIVE_ADDRESS: {
|
||||||
s_word offset = res.address;
|
s_word offset = res.address;
|
||||||
if (offset < 0 && ((word)(-offset)) > *inst_count)
|
if (offset < 0 && ((word)(-offset)) > inst_count)
|
||||||
{
|
{
|
||||||
free(label_registry.data);
|
free(label_registry.data);
|
||||||
return PERR_INVALID_RELATIVE_ADDRESS;
|
return PERR_INVALID_RELATIVE_ADDRESS;
|
||||||
}
|
}
|
||||||
results[i].instruction.operand.as_word = ((s_word)*inst_count) + offset;
|
results[i].instruction.operand.as_word = ((s_word)inst_count) + offset;
|
||||||
(*inst_count)++;
|
inst_count++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case PRES_GLOBAL_LABEL: {
|
case PRES_GLOBAL_LABEL: {
|
||||||
@@ -547,14 +547,15 @@ perr_t process_presults(presult_t *results, size_t res_count,
|
|||||||
case PRES_LABEL_ADDRESS:
|
case PRES_LABEL_ADDRESS:
|
||||||
case PRES_COMPLETE_RESULT:
|
case PRES_COMPLETE_RESULT:
|
||||||
default:
|
default:
|
||||||
(*inst_count)++;
|
inst_count++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
darr_t instr_darr = {0};
|
darr_t instr_darr = {0};
|
||||||
darr_init(&instr_darr, sizeof(**instructions));
|
darr_init(&instr_darr, sizeof(inst_t));
|
||||||
|
|
||||||
|
prog_header_t header = {0};
|
||||||
if (global_start_defined)
|
if (global_start_defined)
|
||||||
{
|
{
|
||||||
label_t label =
|
label_t label =
|
||||||
@@ -566,9 +567,7 @@ perr_t process_presults(presult_t *results, size_t res_count,
|
|||||||
free(label_registry.data);
|
free(label_registry.data);
|
||||||
return PERR_UNKNOWN_LABEL;
|
return PERR_UNKNOWN_LABEL;
|
||||||
}
|
}
|
||||||
inst_t initial_jump = INST_JUMP_ABS(label.addr);
|
header.start_address = label.addr;
|
||||||
darr_append_bytes(&instr_darr, (byte *)&initial_jump, sizeof(initial_jump));
|
|
||||||
(*inst_count)++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (size_t i = 0; i < res_count; ++i)
|
for (size_t i = 0; i < res_count; ++i)
|
||||||
@@ -606,11 +605,17 @@ perr_t process_presults(presult_t *results, size_t res_count,
|
|||||||
}
|
}
|
||||||
|
|
||||||
free(label_registry.data);
|
free(label_registry.data);
|
||||||
*instructions = (inst_t *)instr_darr.data;
|
prog_t *program =
|
||||||
|
malloc(sizeof(**program_ptr) + (sizeof(inst_t) * inst_count));
|
||||||
|
program->header = header;
|
||||||
|
program->count = inst_count;
|
||||||
|
memcpy(program->instructions, instr_darr.data, instr_darr.used);
|
||||||
|
free(instr_darr.data);
|
||||||
|
*program_ptr = program;
|
||||||
return PERR_OK;
|
return PERR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
perr_t parse_stream(token_stream_t *stream, inst_t **ret, size_t *size)
|
perr_t parse_stream(token_stream_t *stream, prog_t **program_ptr)
|
||||||
{
|
{
|
||||||
darr_t presults = {0};
|
darr_t presults = {0};
|
||||||
darr_init(&presults, sizeof(presult_t));
|
darr_init(&presults, sizeof(presult_t));
|
||||||
@@ -634,8 +639,9 @@ perr_t parse_stream(token_stream_t *stream, inst_t **ret, size_t *size)
|
|||||||
++stream->used;
|
++stream->used;
|
||||||
}
|
}
|
||||||
|
|
||||||
perr_t perr = process_presults((presult_t *)presults.data,
|
perr_t perr =
|
||||||
presults.used / sizeof(presult_t), ret, size);
|
process_presults((presult_t *)presults.data,
|
||||||
|
presults.used / sizeof(presult_t), program_ptr);
|
||||||
for (size_t i = 0; i < (presults.used / sizeof(presult_t)); ++i)
|
for (size_t i = 0; i < (presults.used / sizeof(presult_t)); ++i)
|
||||||
{
|
{
|
||||||
presult_t res = ((presult_t *)presults.data)[i];
|
presult_t res = ((presult_t *)presults.data)[i];
|
||||||
|
|||||||
@@ -59,7 +59,7 @@ typedef struct
|
|||||||
label_t search_labels(label_t *, size_t, char *);
|
label_t search_labels(label_t *, size_t, char *);
|
||||||
|
|
||||||
perr_t parse_next(token_stream_t *, presult_t *);
|
perr_t parse_next(token_stream_t *, presult_t *);
|
||||||
perr_t process_presults(presult_t *, size_t, inst_t **, size_t *);
|
perr_t process_presults(presult_t *, size_t, prog_t **);
|
||||||
perr_t parse_stream(token_stream_t *, inst_t **, size_t *);
|
perr_t parse_stream(token_stream_t *, prog_t **);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user