Small Fixes
All checks were successful
CI / Build (AMD64) (push) Successful in 21m1s
CI / Build (ARM64) (push) Successful in 22m8s
CI / Build (ARMHF) (push) Successful in 12m3s
CI / Test (AMD64, Server) (push) Successful in 2m16s
CI / Test (ARM64, Client) (push) Successful in 4m4s
CI / Build Example Mods (push) Successful in 2m10s
CI / Test (ARM64, Server) (push) Successful in 58s
CI / Test (AMD64, Client) (push) Successful in 6m13s
CI / Test (ARMHF, Client) (push) Successful in 4m15s
CI / Test (ARMHF, Server) (push) Successful in 1m11s
CI / Release (push) Has been skipped
All checks were successful
CI / Build (AMD64) (push) Successful in 21m1s
CI / Build (ARM64) (push) Successful in 22m8s
CI / Build (ARMHF) (push) Successful in 12m3s
CI / Test (AMD64, Server) (push) Successful in 2m16s
CI / Test (ARM64, Client) (push) Successful in 4m4s
CI / Build Example Mods (push) Successful in 2m10s
CI / Test (ARM64, Server) (push) Successful in 58s
CI / Test (AMD64, Client) (push) Successful in 6m13s
CI / Test (ARMHF, Client) (push) Successful in 4m15s
CI / Test (ARMHF, Server) (push) Successful in 1m11s
CI / Release (push) Has been skipped
This commit is contained in:
parent
63e2525ee9
commit
72372c7457
@ -1,50 +1,43 @@
|
|||||||
#include <libreborn/libreborn.h>
|
#include <libreborn/libreborn.h>
|
||||||
#include "patch-internal.h"
|
#include "patch-internal.h"
|
||||||
|
|
||||||
// Generate A BL Instruction
|
// Extract Target Address From B(L) Instruction
|
||||||
#define INSTRUCTION_RANGE 32000000
|
static void *extract_from_bl_instruction(unsigned char *from, const uint32_t instruction) {
|
||||||
static uint64_t nice_diff_64(uint64_t a, uint64_t b) {
|
// Extract The Signed 24-Bit Immediate Value
|
||||||
if (a > b) {
|
int32_t imm24 = int32_t(instruction) & 0x00ffffff;
|
||||||
return a - b;
|
// Sign-Extend
|
||||||
} else {
|
if (imm24 & 0x00800000) {
|
||||||
return b - a;
|
imm24 |= int32_t(0xff000000);
|
||||||
}
|
}
|
||||||
|
// Calculate Offset
|
||||||
|
const int32_t offset = imm24 << 2;
|
||||||
|
// Compute Target Address
|
||||||
|
return from + 8 + offset;
|
||||||
}
|
}
|
||||||
uint32_t generate_bl_instruction(void *from, void *to, int use_b_instruction) {
|
void *extract_from_bl_instruction(unsigned char *from) {
|
||||||
// Check Instruction Range
|
return extract_from_bl_instruction(from, *(uint32_t *) from);
|
||||||
if (nice_diff_64((uint64_t) to, (uint64_t) from) > INSTRUCTION_RANGE) {
|
}
|
||||||
IMPOSSIBLE();
|
|
||||||
|
// Generate A BL Instruction
|
||||||
|
uint32_t generate_bl_instruction(void *from, void *to, const int use_b_instruction) {
|
||||||
|
const uint32_t from_addr = uint32_t(from);
|
||||||
|
const uint32_t to_addr = uint32_t(to);
|
||||||
|
|
||||||
|
// Calculate The Offset
|
||||||
|
const int32_t offset = int32_t((to_addr - from_addr - 8) >> 2); // Account For The 2-Bit Shift
|
||||||
|
|
||||||
|
// Create the instruction
|
||||||
|
uint32_t instruction = use_b_instruction ? B_INSTRUCTION : BL_INSTRUCTION;
|
||||||
|
instruction *= 0x1000000;
|
||||||
|
|
||||||
|
// Set The Offset (Last 24 Bits)
|
||||||
|
instruction |= (offset & 0x00FFFFFF);
|
||||||
|
|
||||||
|
// Check
|
||||||
|
if (to != extract_from_bl_instruction((unsigned char *) from, instruction)) {
|
||||||
|
ERR("Unable To Create Branch Instruction From %p To %p", from, to);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create New Instruction
|
|
||||||
uint32_t instruction;
|
|
||||||
unsigned char *instruction_array = (unsigned char *) &instruction;
|
|
||||||
instruction_array[3] = use_b_instruction ? B_INSTRUCTION : BL_INSTRUCTION;
|
|
||||||
|
|
||||||
// Determine PC
|
|
||||||
unsigned char *pc = ((unsigned char *) from) + 8;
|
|
||||||
int32_t offset = (int32_t) to - (int32_t) pc;
|
|
||||||
int32_t target = offset >> 2;
|
|
||||||
|
|
||||||
// Set Instruction Offset
|
|
||||||
unsigned char *target_array = (unsigned char *) ⌖
|
|
||||||
instruction_array[0] = target_array[0];
|
|
||||||
instruction_array[1] = target_array[1];
|
|
||||||
instruction_array[2] = target_array[2];
|
|
||||||
|
|
||||||
// Return
|
// Return
|
||||||
return instruction;
|
return instruction;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Extract Target Address From B(L) Instruction
|
|
||||||
void *extract_from_bl_instruction(unsigned char *from) {
|
|
||||||
// Calculate PC
|
|
||||||
unsigned char *pc = ((unsigned char *) from) + 8;
|
|
||||||
|
|
||||||
// Extract Offset From Instruction
|
|
||||||
int32_t target = *(int32_t *) from;
|
|
||||||
target = (target << 8) >> 8;
|
|
||||||
int32_t offset = target << 2;
|
|
||||||
// Add PC To Offset
|
|
||||||
return (void *) (pc + offset);
|
|
||||||
}
|
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
// Allow Disabling Interaction
|
// Allow Disabling Interaction
|
||||||
static void update_cursor();
|
static void update_cursor();
|
||||||
static int is_interactable = 1;
|
static int is_interactable = 1;
|
||||||
void media_set_interactable(int toggle) {
|
void media_set_interactable(const int toggle) {
|
||||||
if (bool(toggle) != is_interactable) {
|
if (bool(toggle) != is_interactable) {
|
||||||
is_interactable = toggle;
|
is_interactable = toggle;
|
||||||
update_cursor();
|
update_cursor();
|
||||||
|
Loading…
Reference in New Issue
Block a user