picodrive/cpu/drc/cmn.c
notaz eac7a97e4f drc: align tcache_default to 64k on arm
Newer arm64 hw supports 64k pages, and recent Linux distros provide
kernel packages like linux-image-generic-64k (can be used on r-pi4
with Ubuntu for example). It affects 32bit mode also, so assume that
an arm32 binary compiled for vfp may be used on such kernel.

Without this mprotect() fails to set exec permission because of bad
alignment.
2024-03-09 22:02:10 +01:00

62 lines
1.4 KiB
C

/*
* PicoDrive
* Copyright (C) 2009,2010 notaz
*
* This work is licensed under the terms of MAME license.
* See COPYING file in the top-level directory.
*/
#include <stdio.h>
#include <pico/pico_int.h>
#include "cmn.h"
#if defined(__aarch64__) || defined(__VFP_FP__)
// might be running on a 64k-page kernel
#define PICO_PAGE_ALIGN 65536
#else
#define PICO_PAGE_ALIGN 4096
#endif
u8 ALIGNED(PICO_PAGE_ALIGN) tcache_default[DRC_TCACHE_SIZE];
u8 *tcache;
void drc_cmn_init(void)
{
int ret;
tcache = plat_mem_get_for_drc(DRC_TCACHE_SIZE);
if (tcache == NULL)
tcache = tcache_default;
ret = plat_mem_set_exec(tcache, DRC_TCACHE_SIZE);
elprintf(EL_STATUS, "drc_cmn_init: %p, %zd bytes: %d",
tcache, DRC_TCACHE_SIZE, ret);
#ifdef __arm__
if (PicoIn.opt & POPT_EN_DRC)
{
static int test_done;
if (!test_done)
{
int *test_out = (void *)tcache;
int (*testfunc)(void) = (void *)tcache;
elprintf(EL_STATUS, "testing if we can run recompiled code..");
*test_out++ = 0xe3a000dd; // mov r0, 0xdd
*test_out++ = 0xe12fff1e; // bx lr
cache_flush_d_inval_i(tcache, test_out);
// we'll usually crash on broken platforms or bad ports,
// but do a value check too just in case
ret = testfunc();
elprintf(EL_STATUS, "test %s.", ret == 0xdd ? "passed" : "failed");
test_done = 1;
}
}
#endif
}
void drc_cmn_cleanup(void)
{
}
// vim:shiftwidth=2:expandtab