2026-02-05 13:26:07 +00:00
|
|
|
/**
|
|
|
|
|
* @file runmem.h
|
|
|
|
|
* @brief Header file for runmem.c, which contains core functions of
|
|
|
|
|
* the runner to receive data, code and patch instructions, perform
|
|
|
|
|
* patching, and jump to the entry point of the copapy program.
|
|
|
|
|
*/
|
|
|
|
|
|
2025-10-03 21:09:25 +00:00
|
|
|
#ifndef RUNMEM_H
|
|
|
|
|
#define RUNMEM_H
|
|
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
2025-11-03 22:23:19 +00:00
|
|
|
#ifdef ENABLE_LOGGING
|
|
|
|
|
#define LOG(...) printf(__VA_ARGS__)
|
|
|
|
|
#define BLOG(...) printf(__VA_ARGS__)
|
|
|
|
|
#elif ENABLE_BASIC_LOGGING
|
|
|
|
|
#define LOG(...)
|
|
|
|
|
#define BLOG(...) printf(__VA_ARGS__)
|
|
|
|
|
#else
|
|
|
|
|
#define LOG(...)
|
|
|
|
|
#define BLOG(...)
|
|
|
|
|
#endif
|
|
|
|
|
|
2025-10-03 21:09:25 +00:00
|
|
|
/* Command opcodes used by the parser */
|
2025-11-03 01:14:14 +00:00
|
|
|
#define ALLOCATE_DATA 1
|
|
|
|
|
#define COPY_DATA 2
|
|
|
|
|
#define ALLOCATE_CODE 3
|
|
|
|
|
#define COPY_CODE 4
|
|
|
|
|
#define PATCH_FUNC 0x1000
|
2026-01-26 22:57:15 +00:00
|
|
|
#define PATCH_FUNC_ARM32_THM 0x1005
|
2025-11-03 01:14:14 +00:00
|
|
|
#define PATCH_OBJECT 0x2000
|
|
|
|
|
#define PATCH_OBJECT_HI21 0x2001
|
2025-11-03 20:51:58 +00:00
|
|
|
#define PATCH_OBJECT_ABS 0x2002
|
2025-11-09 14:45:37 +00:00
|
|
|
#define PATCH_OBJECT_REL 0x2003
|
2025-11-17 08:00:23 +00:00
|
|
|
#define PATCH_OBJECT_ARM32_ABS 0x2004
|
2026-03-02 20:28:05 +00:00
|
|
|
#define PATCH_OBJECT_ARM32_ABS_THM 0x2006
|
2025-11-03 01:14:14 +00:00
|
|
|
#define ENTRY_POINT 7
|
|
|
|
|
#define RUN_PROG 64
|
|
|
|
|
#define READ_DATA 65
|
|
|
|
|
#define END_COM 256
|
|
|
|
|
#define FREE_MEMORY 257
|
|
|
|
|
#define DUMP_CODE 258
|
2025-10-03 21:09:25 +00:00
|
|
|
|
2025-12-16 15:15:50 +00:00
|
|
|
/* Entry point type */
|
2025-10-03 21:09:25 +00:00
|
|
|
typedef int (*entry_point_t)(void);
|
|
|
|
|
|
2025-12-16 15:15:50 +00:00
|
|
|
/* Struct for run-time memory state */
|
|
|
|
|
typedef struct runmem_s {
|
|
|
|
|
uint8_t *data_memory; // Pointer to data memory
|
|
|
|
|
uint32_t data_memory_len; // Length of data memory
|
|
|
|
|
uint8_t *executable_memory; // Pointer to executable memory
|
|
|
|
|
uint32_t executable_memory_len; // Length of executable memory
|
|
|
|
|
int data_offs; // Offset of data memory relative to executable memory
|
|
|
|
|
entry_point_t entr_point; // Entry point function pointer
|
|
|
|
|
} runmem_t;
|
2025-10-03 21:09:25 +00:00
|
|
|
|
|
|
|
|
/* Command parser: takes a pointer to the command stream and returns
|
|
|
|
|
an error flag (0 on success according to current code) */
|
2025-12-16 15:15:50 +00:00
|
|
|
int parse_commands(runmem_t *context, uint8_t *bytes);
|
2025-10-03 21:09:25 +00:00
|
|
|
|
|
|
|
|
/* Free program and data memory */
|
2025-12-16 15:15:50 +00:00
|
|
|
void free_memory(runmem_t *context);
|
2025-10-03 21:09:25 +00:00
|
|
|
|
|
|
|
|
#endif /* RUNMEM_H */
|