mirror of https://github.com/xemu-project/xemu.git
OpenRISC Fixes for 7.0
- A few or1ksim fixes and enhancements - A fix for OpenRISC tcg backend around delay slot handling -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEE2cRzVK74bBA6Je/xw7McLV5mJ+QFAmKAWKsACgkQw7McLV5m J+SoFg/8Dlrc2BqjjXw9gpaQ18+3BRI6dMVPqHA22VJks88gykH7UWLUbrCxtKnS SBcIcpzu17nKDdfwYWndqCr0UBM/zM3JzFrTv4QEhTEg6Np7lSM2KVNEhjBPVGoW A7QOjPFrwItWOfAx6hrcczpj+L50iKuWeMW0XnEfqSeDYisxZcSp2yMoe5h3y7bF tlpo+ha/ir/fd2kMlFrQlPWYiWkWM05RLJJOlXhdRMF7hrW5qlHqEB/SVykUTf7V 6fqOFvY6r3vE5OFm0Scgf/k2AJIxwV8qXkBJ5/egv+ZqUidZBQ9nXtOw++vF2AWp eKoU2/c2XIxiF1Xdpgdi6a/CxlLqrr9jraQROB3GpaL9zGQvd//wUCg0F+QLicLv avq4lvNmnat89aXj1DQ+DWpLy0zaZFGmxsPR+KeBJ2wkuEJ3Vd4+uiuAyXnm9M8D wEE8mgFQYsTL1WlgHF4uNTDIx8OLS+4gYlBE3tffRksxyLLwzKHHgAfLdNZvhfx8 QZBuPy+yyO8zjr3RUVUArBs/ukZHP1QwDE6uxmPKV34tvVEbFVeSFY3a1LmYV3w5 mZNALNqf+h5Dq5Qo7f7cGNMrzhL53GTWPNX0MK5+SBDZF3/fpPZyvCr4Zd69Z5tD +YClfWBv8HPjdUf+IFHqyE8rURw/sgNvgB76GpalwcUYXRr7zTM= =tmP4 -----END PGP SIGNATURE----- Merge tag 'or1k-pull-request-20220515' of https://github.com/stffrdhrn/qemu into staging OpenRISC Fixes for 7.0 - A few or1ksim fixes and enhancements - A fix for OpenRISC tcg backend around delay slot handling # -----BEGIN PGP SIGNATURE----- # # iQIzBAABCAAdFiEE2cRzVK74bBA6Je/xw7McLV5mJ+QFAmKAWKsACgkQw7McLV5m # J+SoFg/8Dlrc2BqjjXw9gpaQ18+3BRI6dMVPqHA22VJks88gykH7UWLUbrCxtKnS # SBcIcpzu17nKDdfwYWndqCr0UBM/zM3JzFrTv4QEhTEg6Np7lSM2KVNEhjBPVGoW # A7QOjPFrwItWOfAx6hrcczpj+L50iKuWeMW0XnEfqSeDYisxZcSp2yMoe5h3y7bF # tlpo+ha/ir/fd2kMlFrQlPWYiWkWM05RLJJOlXhdRMF7hrW5qlHqEB/SVykUTf7V # 6fqOFvY6r3vE5OFm0Scgf/k2AJIxwV8qXkBJ5/egv+ZqUidZBQ9nXtOw++vF2AWp # eKoU2/c2XIxiF1Xdpgdi6a/CxlLqrr9jraQROB3GpaL9zGQvd//wUCg0F+QLicLv # avq4lvNmnat89aXj1DQ+DWpLy0zaZFGmxsPR+KeBJ2wkuEJ3Vd4+uiuAyXnm9M8D # wEE8mgFQYsTL1WlgHF4uNTDIx8OLS+4gYlBE3tffRksxyLLwzKHHgAfLdNZvhfx8 # QZBuPy+yyO8zjr3RUVUArBs/ukZHP1QwDE6uxmPKV34tvVEbFVeSFY3a1LmYV3w5 # mZNALNqf+h5Dq5Qo7f7cGNMrzhL53GTWPNX0MK5+SBDZF3/fpPZyvCr4Zd69Z5tD # +YClfWBv8HPjdUf+IFHqyE8rURw/sgNvgB76GpalwcUYXRr7zTM= # =tmP4 # -----END PGP SIGNATURE----- # gpg: Signature made Sat 14 May 2022 06:34:35 PM PDT # gpg: using RSA key D9C47354AEF86C103A25EFF1C3B31C2D5E6627E4 # gpg: Good signature from "Stafford Horne <shorne@gmail.com>" [unknown] # gpg: WARNING: This key is not certified with a trusted signature! # gpg: There is no indication that the signature belongs to the owner. # Primary key fingerprint: D9C4 7354 AEF8 6C10 3A25 EFF1 C3B3 1C2D 5E66 27E4 * tag 'or1k-pull-request-20220515' of https://github.com/stffrdhrn/qemu: target/openrisc: Do not reset delay slot flag on early tb exit hw/openrisc: use right OMPIC size variable hw/openrisc: support 4 serial ports in or1ksim hw/openrisc: page-align FDT address Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
commit
10c2a0c5e7
|
@ -71,6 +71,10 @@ enum {
|
|||
OR1KSIM_ETHOC_IRQ = 4,
|
||||
};
|
||||
|
||||
enum {
|
||||
OR1KSIM_UART_COUNT = 4
|
||||
};
|
||||
|
||||
static const struct MemmapEntry {
|
||||
hwaddr base;
|
||||
hwaddr size;
|
||||
|
@ -78,7 +82,7 @@ static const struct MemmapEntry {
|
|||
[OR1KSIM_DRAM] = { 0x00000000, 0 },
|
||||
[OR1KSIM_UART] = { 0x90000000, 0x100 },
|
||||
[OR1KSIM_ETHOC] = { 0x92000000, 0x800 },
|
||||
[OR1KSIM_OMPIC] = { 0x98000000, 16 },
|
||||
[OR1KSIM_OMPIC] = { 0x98000000, OR1KSIM_CPUS_MAX * 8 },
|
||||
};
|
||||
|
||||
static struct openrisc_boot_info {
|
||||
|
@ -239,11 +243,13 @@ static void openrisc_sim_ompic_init(Or1ksimState *state, hwaddr base,
|
|||
|
||||
static void openrisc_sim_serial_init(Or1ksimState *state, hwaddr base,
|
||||
hwaddr size, int num_cpus,
|
||||
OpenRISCCPU *cpus[], int irq_pin)
|
||||
OpenRISCCPU *cpus[], int irq_pin,
|
||||
int uart_idx)
|
||||
{
|
||||
void *fdt = state->fdt;
|
||||
char *nodename;
|
||||
qemu_irq serial_irq;
|
||||
char alias[sizeof("uart0")];
|
||||
int i;
|
||||
|
||||
if (num_cpus > 1) {
|
||||
|
@ -258,7 +264,8 @@ static void openrisc_sim_serial_init(Or1ksimState *state, hwaddr base,
|
|||
serial_irq = get_cpu_irq(cpus, 0, irq_pin);
|
||||
}
|
||||
serial_mm_init(get_system_memory(), base, 0, serial_irq, 115200,
|
||||
serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||
serial_hd(OR1KSIM_UART_COUNT - uart_idx - 1),
|
||||
DEVICE_NATIVE_ENDIAN);
|
||||
|
||||
/* Add device tree node for serial. */
|
||||
nodename = g_strdup_printf("/serial@%" HWADDR_PRIx, base);
|
||||
|
@ -271,7 +278,8 @@ static void openrisc_sim_serial_init(Or1ksimState *state, hwaddr base,
|
|||
|
||||
/* The /chosen node is created during fdt creation. */
|
||||
qemu_fdt_setprop_string(fdt, "/chosen", "stdout-path", nodename);
|
||||
qemu_fdt_setprop_string(fdt, "/aliases", "uart0", nodename);
|
||||
snprintf(alias, sizeof(alias), "uart%d", uart_idx);
|
||||
qemu_fdt_setprop_string(fdt, "/aliases", alias, nodename);
|
||||
g_free(nodename);
|
||||
}
|
||||
|
||||
|
@ -356,7 +364,7 @@ static uint32_t openrisc_load_fdt(Or1ksimState *state, hwaddr load_start,
|
|||
}
|
||||
|
||||
/* We put fdt right after the kernel and/or initrd. */
|
||||
fdt_addr = ROUND_UP(load_start, 4);
|
||||
fdt_addr = TARGET_PAGE_ALIGN(load_start);
|
||||
|
||||
ret = fdt_pack(fdt);
|
||||
/* Should only fail if we've built a corrupted tree */
|
||||
|
@ -410,13 +418,15 @@ static void openrisc_sim_init(MachineState *machine)
|
|||
|
||||
if (smp_cpus > 1) {
|
||||
openrisc_sim_ompic_init(state, or1ksim_memmap[OR1KSIM_OMPIC].base,
|
||||
or1ksim_memmap[OR1KSIM_UART].size,
|
||||
or1ksim_memmap[OR1KSIM_OMPIC].size,
|
||||
smp_cpus, cpus, OR1KSIM_OMPIC_IRQ);
|
||||
}
|
||||
|
||||
openrisc_sim_serial_init(state, or1ksim_memmap[OR1KSIM_UART].base,
|
||||
or1ksim_memmap[OR1KSIM_UART].size, smp_cpus, cpus,
|
||||
OR1KSIM_UART_IRQ);
|
||||
for (n = 0; n < OR1KSIM_UART_COUNT; ++n)
|
||||
openrisc_sim_serial_init(state, or1ksim_memmap[OR1KSIM_UART].base +
|
||||
or1ksim_memmap[OR1KSIM_UART].size * n,
|
||||
or1ksim_memmap[OR1KSIM_UART].size,
|
||||
smp_cpus, cpus, OR1KSIM_UART_IRQ, n);
|
||||
|
||||
load_addr = openrisc_load_kernel(ram_size, kernel_filename);
|
||||
if (load_addr > 0) {
|
||||
|
|
|
@ -21,6 +21,7 @@
|
|||
#include "qapi/error.h"
|
||||
#include "qemu/qemu-print.h"
|
||||
#include "cpu.h"
|
||||
#include "exec/exec-all.h"
|
||||
|
||||
static void openrisc_cpu_set_pc(CPUState *cs, vaddr value)
|
||||
{
|
||||
|
@ -30,6 +31,15 @@ static void openrisc_cpu_set_pc(CPUState *cs, vaddr value)
|
|||
cpu->env.dflag = 0;
|
||||
}
|
||||
|
||||
static void openrisc_cpu_synchronize_from_tb(CPUState *cs,
|
||||
const TranslationBlock *tb)
|
||||
{
|
||||
OpenRISCCPU *cpu = OPENRISC_CPU(cs);
|
||||
|
||||
cpu->env.pc = tb->pc;
|
||||
}
|
||||
|
||||
|
||||
static bool openrisc_cpu_has_work(CPUState *cs)
|
||||
{
|
||||
return cs->interrupt_request & (CPU_INTERRUPT_HARD |
|
||||
|
@ -186,6 +196,7 @@ static const struct SysemuCPUOps openrisc_sysemu_ops = {
|
|||
|
||||
static const struct TCGCPUOps openrisc_tcg_ops = {
|
||||
.initialize = openrisc_translate_init,
|
||||
.synchronize_from_tb = openrisc_cpu_synchronize_from_tb,
|
||||
|
||||
#ifndef CONFIG_USER_ONLY
|
||||
.tlb_fill = openrisc_cpu_tlb_fill,
|
||||
|
|
Loading…
Reference in New Issue