commit
964d4f7211
@ -1,97 +0,0 @@ |
||||
/dts-v1/; |
||||
/ { |
||||
compatible = "riscv32 nx25"; |
||||
#address-cells = <1>; |
||||
#size-cells = <1>; |
||||
interrupt-parent = <&intc>; |
||||
|
||||
aliases { |
||||
uart0 = &serial0; |
||||
ethernet0 = &mac0; |
||||
spi0 = &spi; |
||||
} ; |
||||
|
||||
chosen { |
||||
bootargs = "console=ttyS0,38400n8 earlyprintk=uart8250-32bit,0xf0300000 debug loglevel=7"; |
||||
stdout-path = "uart0:38400n8"; |
||||
tick-timer = &timer0; |
||||
}; |
||||
|
||||
memory@0 { |
||||
device_type = "memory"; |
||||
reg = <0x00000000 0x40000000>; |
||||
}; |
||||
|
||||
spiclk: virt_100mhz { |
||||
#clock-cells = <0>; |
||||
compatible = "fixed-clock"; |
||||
clock-frequency = <100000000>; |
||||
}; |
||||
|
||||
cpus { |
||||
#address-cells = <1>; |
||||
#size-cells = <0>; |
||||
cpu@0 { |
||||
compatible = "andestech,n13"; |
||||
reg = <0>; |
||||
/* FIXME: to fill correct frqeuency */ |
||||
clock-frequency = <60000000>; |
||||
}; |
||||
}; |
||||
|
||||
intc: interrupt-controller { |
||||
compatible = "andestech,atnointc010"; |
||||
#interrupt-cells = <1>; |
||||
interrupt-controller; |
||||
}; |
||||
|
||||
serial0: serial@f0300000 { |
||||
compatible = "andestech,uart16550", "ns16550a"; |
||||
reg = <0xf0300000 0x1000>; |
||||
interrupts = <7 4>; |
||||
clock-frequency = <19660800>; |
||||
reg-shift = <2>; |
||||
reg-offset = <32>; |
||||
no-loopback-test = <1>; |
||||
}; |
||||
|
||||
timer0: timer@f0400000 { |
||||
compatible = "andestech,atcpit100"; |
||||
reg = <0xf0400000 0x1000>; |
||||
interrupts = <2 4>; |
||||
clock-frequency = <40000000>; |
||||
}; |
||||
|
||||
mac0: mac@e0100000 { |
||||
compatible = "andestech,atmac100"; |
||||
reg = <0xe0100000 0x1000>; |
||||
interrupts = <25 4>; |
||||
}; |
||||
|
||||
mmc0: mmc@f0e00000 { |
||||
compatible = "andestech,atsdc010"; |
||||
max-frequency = <100000000>; |
||||
fifo-depth = <0x10>; |
||||
reg = <0xf0e00000 0x1000>; |
||||
interrupts = <17 4>; |
||||
cap-sd-highspeed; |
||||
}; |
||||
|
||||
spi: spi@f0b00000 { |
||||
compatible = "andestech,atcspi200"; |
||||
reg = <0xf0b00000 0x1000>; |
||||
#address-cells = <1>; |
||||
#size-cells = <0>; |
||||
num-cs = <1>; |
||||
clocks = <&spiclk>; |
||||
interrupts = <3 4>; |
||||
flash@0 { |
||||
compatible = "spi-flash"; |
||||
spi-max-frequency = <50000000>; |
||||
reg = <0>; |
||||
spi-cpol; |
||||
spi-cpha; |
||||
}; |
||||
}; |
||||
|
||||
}; |
@ -0,0 +1,149 @@ |
||||
/dts-v1/; |
||||
|
||||
/ { |
||||
#address-cells = <2>; |
||||
#size-cells = <2>; |
||||
compatible = "andestech,ax25"; |
||||
model = "andestech,ax25"; |
||||
|
||||
aliases { |
||||
uart0 = &serial0; |
||||
spi0 = &spi; |
||||
} ; |
||||
|
||||
chosen { |
||||
bootargs = "console=ttyS0,38400n8 earlyprintk=uart8250-32bit,0xf0300000 debug loglevel=7"; |
||||
stdout-path = "uart0:38400n8"; |
||||
}; |
||||
|
||||
cpus { |
||||
#address-cells = <1>; |
||||
#size-cells = <0>; |
||||
timebase-frequency = <10000000>; |
||||
CPU0: cpu@0 { |
||||
device_type = "cpu"; |
||||
reg = <0>; |
||||
status = "okay"; |
||||
compatible = "riscv"; |
||||
riscv,isa = "rv64imafdc"; |
||||
mmu-type = "riscv,sv39"; |
||||
clock-frequency = <60000000>; |
||||
CPU0_intc: interrupt-controller { |
||||
#interrupt-cells = <1>; |
||||
interrupt-controller; |
||||
compatible = "riscv,cpu-intc"; |
||||
}; |
||||
}; |
||||
}; |
||||
|
||||
memory@0 { |
||||
device_type = "memory"; |
||||
reg = <0x0 0x00000000 0x0 0x40000000>; |
||||
}; |
||||
|
||||
soc { |
||||
#address-cells = <2>; |
||||
#size-cells = <2>; |
||||
compatible = "andestech,riscv-ae350-soc"; |
||||
ranges; |
||||
}; |
||||
|
||||
plmt0@e6000000 { |
||||
compatible = "riscv,plmt0"; |
||||
interrupts-extended = <&CPU0_intc 7>; |
||||
reg = <0x0 0xe6000000 0x0 0x100000>; |
||||
}; |
||||
|
||||
plic0: interrupt-controller@e4000000 { |
||||
compatible = "riscv,plic0"; |
||||
#address-cells = <2>; |
||||
#interrupt-cells = <2>; |
||||
interrupt-controller; |
||||
reg = <0x0 0xe4000000 0x0 0x2000000>; |
||||
riscv,ndev=<31>; |
||||
interrupts-extended = <&CPU0_intc 11 &CPU0_intc 9>; |
||||
}; |
||||
|
||||
plic1: interrupt-controller@e6400000 { |
||||
compatible = "riscv,plic1"; |
||||
#address-cells = <2>; |
||||
#interrupt-cells = <2>; |
||||
interrupt-controller; |
||||
reg = <0x0 0xe6400000 0x0 0x400000>; |
||||
riscv,ndev=<1>; |
||||
interrupts-extended = <&CPU0_intc 3>; |
||||
}; |
||||
|
||||
spiclk: virt_100mhz { |
||||
#clock-cells = <0>; |
||||
compatible = "fixed-clock"; |
||||
clock-frequency = <100000000>; |
||||
}; |
||||
|
||||
timer0: timer@f0400000 { |
||||
compatible = "andestech,atcpit100"; |
||||
reg = <0x0 0xf0400000 0x0 0x1000>; |
||||
clock-frequency = <40000000>; |
||||
interrupts = <3 4>; |
||||
interrupt-parent = <&plic0>; |
||||
}; |
||||
|
||||
serial0: serial@f0300000 { |
||||
compatible = "andestech,uart16550", "ns16550a"; |
||||
reg = <0x0 0xf0300000 0x0 0x1000>; |
||||
interrupts = <9 4>; |
||||
clock-frequency = <19660800>; |
||||
reg-shift = <2>; |
||||
reg-offset = <32>; |
||||
no-loopback-test = <1>; |
||||
interrupt-parent = <&plic0>; |
||||
}; |
||||
|
||||
mac0: mac@e0100000 { |
||||
compatible = "andestech,atmac100"; |
||||
reg = <0x0 0xe0100000 0x0 0x1000>; |
||||
interrupts = <19 4>; |
||||
interrupt-parent = <&plic0>; |
||||
}; |
||||
|
||||
mmc0: mmc@f0e00000 { |
||||
compatible = "andestech,atfsdc010"; |
||||
max-frequency = <100000000>; |
||||
clock-freq-min-max = <400000 100000000>; |
||||
fifo-depth = <0x10>; |
||||
reg = <0x0 0xf0e00000 0x0 0x1000>; |
||||
interrupts = <18 4>; |
||||
cap-sd-highspeed; |
||||
interrupt-parent = <&plic0>; |
||||
}; |
||||
|
||||
smc0: smc@e0400000 { |
||||
compatible = "andestech,atfsmc020"; |
||||
reg = <0x0 0xe0400000 0x0 0x1000>; |
||||
}; |
||||
|
||||
nor@0,0 { |
||||
compatible = "cfi-flash"; |
||||
reg = <0x0 0x88000000 0x0 0x1000>; |
||||
bank-width = <2>; |
||||
device-width = <1>; |
||||
}; |
||||
|
||||
spi: spi@f0b00000 { |
||||
compatible = "andestech,atcspi200"; |
||||
reg = <0x0 0xf0b00000 0x0 0x1000>; |
||||
#address-cells = <1>; |
||||
#size-cells = <0>; |
||||
num-cs = <1>; |
||||
clocks = <&spiclk>; |
||||
interrupts = <3 4>; |
||||
interrupt-parent = <&plic0>; |
||||
flash@0 { |
||||
compatible = "spi-flash"; |
||||
spi-max-frequency = <50000000>; |
||||
reg = <0>; |
||||
spi-cpol; |
||||
spi-cpha; |
||||
}; |
||||
}; |
||||
}; |
@ -0,0 +1,25 @@ |
||||
/* SPDX-License-Identifier: GPL-2.0+ */ |
||||
/*
|
||||
* (C) Copyright 2018 Alexander Graf <agraf@suse.de> |
||||
*/ |
||||
|
||||
#ifndef _SETJMP_H_ |
||||
#define _SETJMP_H_ 1 |
||||
|
||||
/*
|
||||
* This really should be opaque, but the EFI implementation wrongly |
||||
* assumes that a 'struct jmp_buf_data' is defined. |
||||
*/ |
||||
struct jmp_buf_data { |
||||
/* x2, x8, x9, x18, x19, x20, x21, x22, x23, x24, x25, x26, x27, sp */ |
||||
unsigned long s_regs[12]; /* s0 - s11 */ |
||||
unsigned long ra; |
||||
unsigned long sp; |
||||
}; |
||||
|
||||
typedef struct jmp_buf_data jmp_buf[1]; |
||||
|
||||
int setjmp(jmp_buf jmp); |
||||
void longjmp(jmp_buf jmp, int ret); |
||||
|
||||
#endif /* _SETJMP_H_ */ |
@ -0,0 +1,151 @@ |
||||
/* SPDX-License-Identifier: GPL-2.0+ */ |
||||
/* |
||||
* crt0-efi-riscv.S - PE/COFF header for RISC-V EFI applications |
||||
* |
||||
* Copright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org>
|
||||
* Copright (C) 2018 Alexander Graf <agraf@suse.de>
|
||||
* |
||||
* This file is inspired by arch/arm/lib/crt0_aarch64_efi.S |
||||
*/ |
||||
|
||||
#include <asm-generic/pe.h> |
||||
|
||||
#if __riscv_xlen == 64 |
||||
#define SIZE_LONG 8 |
||||
#define SAVE_LONG(reg, idx) sd reg, (idx*SIZE_LONG)(sp) |
||||
#define LOAD_LONG(reg, idx) ld reg, (idx*SIZE_LONG)(sp) |
||||
#define PE_MACHINE 0x5064 |
||||
#else |
||||
#define SIZE_LONG 4 |
||||
#define SAVE_LONG(reg, idx) sw reg, (idx*SIZE_LONG)(sp) |
||||
#define LOAD_LONG(reg, idx) lw reg, (idx*SIZE_LONG)(sp) |
||||
#define PE_MACHINE 0x5032 |
||||
#endif |
||||
|
||||
|
||||
.section .text.head |
||||
|
||||
/* |
||||
* Magic "MZ" signature for PE/COFF |
||||
*/ |
||||
.globl ImageBase
|
||||
ImageBase: |
||||
.ascii "MZ" |
||||
.skip 58 /* 'MZ' + pad + offset == 64 */ |
||||
.long pe_header - ImageBase /* Offset to the PE header */ |
||||
pe_header: |
||||
.ascii "PE" |
||||
.short 0
|
||||
coff_header: |
||||
.short PE_MACHINE /* RISC-V 64/32-bit */ |
||||
.short 2 /* nr_sections */ |
||||
.long 0 /* TimeDateStamp */ |
||||
.long 0 /* PointerToSymbolTable */ |
||||
.long 1 /* NumberOfSymbols */ |
||||
.short section_table - optional_header /* SizeOfOptionalHeader */ |
||||
/* |
||||
* Characteristics: IMAGE_FILE_DEBUG_STRIPPED | |
||||
* IMAGE_FILE_EXECUTABLE_IMAGE | IMAGE_FILE_LINE_NUMS_STRIPPED |
||||
*/ |
||||
.short 0x206
|
||||
optional_header: |
||||
.short 0x20b /* PE32+ format */ |
||||
.byte 0x02 /* MajorLinkerVersion */ |
||||
.byte 0x14 /* MinorLinkerVersion */ |
||||
.long _edata - _start /* SizeOfCode */ |
||||
.long 0 /* SizeOfInitializedData */ |
||||
.long 0 /* SizeOfUninitializedData */ |
||||
.long _start - ImageBase /* AddressOfEntryPoint */ |
||||
.long _start - ImageBase /* BaseOfCode */ |
||||
|
||||
extra_header_fields: |
||||
.quad 0 /* ImageBase */ |
||||
.long 0x20 /* SectionAlignment */ |
||||
.long 0x8 /* FileAlignment */ |
||||
.short 0 /* MajorOperatingSystemVersion */ |
||||
.short 0 /* MinorOperatingSystemVersion */ |
||||
.short 0 /* MajorImageVersion */ |
||||
.short 0 /* MinorImageVersion */ |
||||
.short 0 /* MajorSubsystemVersion */ |
||||
.short 0 /* MinorSubsystemVersion */ |
||||
.long 0 /* Win32VersionValue */ |
||||
|
||||
.long _edata - ImageBase /* SizeOfImage */ |
||||
|
||||
/* |
||||
* Everything before the kernel image is considered part of the header |
||||
*/ |
||||
.long _start - ImageBase /* SizeOfHeaders */ |
||||
.long 0 /* CheckSum */ |
||||
.short IMAGE_SUBSYSTEM_EFI_APPLICATION /* Subsystem */ |
||||
.short 0 /* DllCharacteristics */ |
||||
.quad 0 /* SizeOfStackReserve */ |
||||
.quad 0 /* SizeOfStackCommit */ |
||||
.quad 0 /* SizeOfHeapReserve */ |
||||
.quad 0 /* SizeOfHeapCommit */ |
||||
.long 0 /* LoaderFlags */ |
||||
.long 0x6 /* NumberOfRvaAndSizes */ |
||||
|
||||
.quad 0 /* ExportTable */ |
||||
.quad 0 /* ImportTable */ |
||||
.quad 0 /* ResourceTable */ |
||||
.quad 0 /* ExceptionTable */ |
||||
.quad 0 /* CertificationTable */ |
||||
.quad 0 /* BaseRelocationTable */ |
||||
|
||||
/* Section table */ |
||||
section_table: |
||||
|
||||
/* |
||||
* The EFI application loader requires a relocation section |
||||
* because EFI applications must be relocatable. This is a |
||||
* dummy section as far as we are concerned. |
||||
*/ |
||||
.ascii ".reloc" |
||||
.byte 0
|
||||
.byte 0 /* end of 0 padding of section name */ |
||||
.long 0
|
||||
.long 0
|
||||
.long 0 /* SizeOfRawData */ |
||||
.long 0 /* PointerToRawData */ |
||||
.long 0 /* PointerToRelocations */ |
||||
.long 0 /* PointerToLineNumbers */ |
||||
.short 0 /* NumberOfRelocations */ |
||||
.short 0 /* NumberOfLineNumbers */ |
||||
.long 0x42100040 /* Characteristics (section flags) */ |
||||
|
||||
|
||||
.ascii ".text" |
||||
.byte 0
|
||||
.byte 0
|
||||
.byte 0 /* end of 0 padding of section name */ |
||||
.long _edata - _start /* VirtualSize */ |
||||
.long _start - ImageBase /* VirtualAddress */ |
||||
.long _edata - _start /* SizeOfRawData */ |
||||
.long _start - ImageBase /* PointerToRawData */ |
||||
|
||||
.long 0 /* PointerToRelocations (0 for executables) */ |
||||
.long 0 /* PointerToLineNumbers (0 for executables) */ |
||||
.short 0 /* NumberOfRelocations (0 for executables) */ |
||||
.short 0 /* NumberOfLineNumbers (0 for executables) */ |
||||
.long 0xe0500020 /* Characteristics (section flags) */ |
||||
|
||||
_start: |
||||
addi sp, sp, -(SIZE_LONG * 3) |
||||
SAVE_LONG(a0, 0) |
||||
SAVE_LONG(a1, 1) |
||||
SAVE_LONG(ra, 2) |
||||
|
||||
lla a0, ImageBase |
||||
lla a1, _DYNAMIC |
||||
call _relocate |
||||
bne a0, zero, 0f |
||||
|
||||
LOAD_LONG(a1, 1) |
||||
LOAD_LONG(a0, 0) |
||||
call efi_main |
||||
|
||||
LOAD_LONG(ra, 2) |
||||
|
||||
0: addi sp, sp, (SIZE_LONG * 3) |
||||
ret |
@ -0,0 +1,71 @@ |
||||
/* SPDX-License-Identifier: GPL-2.0+ */ |
||||
/* |
||||
* U-Boot riscv32 EFI linker script |
||||
* |
||||
* SPDX-License-Identifier: BSD-2-Clause |
||||
* |
||||
* Modified from arch/arm/lib/elf_aarch64_efi.lds |
||||
*/ |
||||
|
||||
OUTPUT_FORMAT("elf32-littleriscv", "elf32-littleriscv", "elf32-littleriscv") |
||||
OUTPUT_ARCH(riscv) |
||||
ENTRY(_start) |
||||
SECTIONS |
||||
{ |
||||
.text 0x0 : { |
||||
_text = .; |
||||
*(.text.head) |
||||
*(.text) |
||||
*(.text.*) |
||||
*(.gnu.linkonce.t.*) |
||||
*(.srodata) |
||||
*(.rodata*) |
||||
. = ALIGN(16); |
||||
} |
||||
_etext = .; |
||||
_text_size = . - _text; |
||||
.dynamic : { *(.dynamic) } |
||||
.data : { |
||||
_data = .; |
||||
*(.sdata) |
||||
*(.data) |
||||
*(.data1) |
||||
*(.data.*) |
||||
*(.got.plt) |
||||
*(.got) |
||||
|
||||
/* |
||||
* The EFI loader doesn't seem to like a .bss section, so we |
||||
* stick it all into .data: |
||||
*/ |
||||
. = ALIGN(16); |
||||
_bss = .; |
||||
*(.sbss) |
||||
*(.scommon) |
||||
*(.dynbss) |
||||
*(.bss) |
||||
*(.bss.*) |
||||
*(COMMON) |
||||
. = ALIGN(16); |
||||
_bss_end = .; |
||||
_edata = .; |
||||
} |
||||
.rela.dyn : { *(.rela.dyn) } |
||||
.rela.plt : { *(.rela.plt) } |
||||
.rela.got : { *(.rela.got) } |
||||
.rela.data : { *(.rela.data) *(.rela.data*) } |
||||
_data_size = . - _etext; |
||||
|
||||
. = ALIGN(4096); |
||||
.dynsym : { *(.dynsym) } |
||||
. = ALIGN(4096); |
||||
.dynstr : { *(.dynstr) } |
||||
. = ALIGN(4096); |
||||
.note.gnu.build-id : { *(.note.gnu.build-id) } |
||||
/DISCARD/ : { |
||||
*(.rel.reloc) |
||||
*(.eh_frame) |
||||
*(.note.GNU-stack) |
||||
} |
||||
.comment 0 : { *(.comment) } |
||||
} |
@ -0,0 +1,71 @@ |
||||
/* SPDX-License-Identifier: GPL-2.0+ */ |
||||
/* |
||||
* U-Boot riscv64 EFI linker script |
||||
* |
||||
* SPDX-License-Identifier: BSD-2-Clause |
||||
* |
||||
* Modified from arch/arm/lib/elf_aarch64_efi.lds |
||||
*/ |
||||
|
||||
OUTPUT_FORMAT("elf64-littleriscv", "elf64-littleriscv", "elf64-littleriscv") |
||||
OUTPUT_ARCH(riscv) |
||||
ENTRY(_start) |
||||
SECTIONS |
||||
{ |
||||
.text 0x0 : { |
||||
_text = .; |
||||
*(.text.head) |
||||
*(.text) |
||||
*(.text.*) |
||||
*(.gnu.linkonce.t.*) |
||||
*(.srodata) |
||||
*(.rodata*) |
||||
. = ALIGN(16); |
||||
} |
||||
_etext = .; |
||||
_text_size = . - _text; |
||||
.dynamic : { *(.dynamic) } |
||||
.data : { |
||||
_data = .; |
||||
*(.sdata) |
||||
*(.data) |
||||
*(.data1) |
||||
*(.data.*) |
||||
*(.got.plt) |
||||
*(.got) |
||||
|
||||
/* |
||||
* The EFI loader doesn't seem to like a .bss section, so we |
||||
* stick it all into .data: |
||||
*/ |
||||
. = ALIGN(16); |
||||
_bss = .; |
||||
*(.sbss) |
||||
*(.scommon) |
||||
*(.dynbss) |
||||
*(.bss) |
||||
*(.bss.*) |
||||
*(COMMON) |
||||
. = ALIGN(16); |
||||
_bss_end = .; |
||||
_edata = .; |
||||
} |
||||
.rela.dyn : { *(.rela.dyn) } |
||||
.rela.plt : { *(.rela.plt) } |
||||
.rela.got : { *(.rela.got) } |
||||
.rela.data : { *(.rela.data) *(.rela.data*) } |
||||
_data_size = . - _etext; |
||||
|
||||
. = ALIGN(4096); |
||||
.dynsym : { *(.dynsym) } |
||||
. = ALIGN(4096); |
||||
.dynstr : { *(.dynstr) } |
||||
. = ALIGN(4096); |
||||
.note.gnu.build-id : { *(.note.gnu.build-id) } |
||||
/DISCARD/ : { |
||||
*(.rel.reloc) |
||||
*(.eh_frame) |
||||
*(.note.GNU-stack) |
||||
} |
||||
.comment 0 : { *(.comment) } |
||||
} |
@ -0,0 +1,98 @@ |
||||
// SPDX-License-Identifier: GPL-2.0+
|
||||
/* reloc_riscv.c - position independent ELF shared object relocator
|
||||
Copyright (C) 2018 Alexander Graf <agraf@suse.de> |
||||
Copyright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org> |
||||
Copyright (C) 1999 Hewlett-Packard Co. |
||||
Contributed by David Mosberger <davidm@hpl.hp.com>. |
||||
|
||||
All rights reserved. |
||||
|
||||
Redistribution and use in source and binary forms, with or without |
||||
modification, are permitted provided that the following conditions |
||||
are met: |
||||
|
||||
* Redistributions of source code must retain the above copyright |
||||
notice, this list of conditions and the following disclaimer. |
||||
* Redistributions in binary form must reproduce the above |
||||
copyright notice, this list of conditions and the following |
||||
disclaimer in the documentation and/or other materials |
||||
provided with the distribution. |
||||
* Neither the name of Hewlett-Packard Co. nor the names of its |
||||
contributors may be used to endorse or promote products derived |
||||
from this software without specific prior written permission. |
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND |
||||
CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, |
||||
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
||||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS |
||||
BE LIABLE FOR ANYDIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, |
||||
OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
||||
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
||||
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR |
||||
TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF |
||||
THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
||||
SUCH DAMAGE. |
||||
*/ |
||||
|
||||
#include <efi.h> |
||||
|
||||
#include <elf.h> |
||||
|
||||
#if __riscv_xlen == 64 |
||||
#define Elf_Dyn Elf64_Dyn |
||||
#define Elf_Rela Elf64_Rela |
||||
#define ELF_R_TYPE ELF64_R_TYPE |
||||
#else |
||||
#define Elf_Dyn Elf32_Dyn |
||||
#define Elf_Rela Elf32_Rela |
||||
#define ELF_R_TYPE ELF32_R_TYPE |
||||
#endif |
||||
|
||||
efi_status_t _relocate(long ldbase, Elf_Dyn *dyn, efi_handle_t image, |
||||
struct efi_system_table *systab) |
||||
{ |
||||
long relsz = 0, relent = 0; |
||||
Elf_Rela *rel = 0; |
||||
unsigned long *addr; |
||||
int i; |
||||
|
||||
for (i = 0; dyn[i].d_tag != DT_NULL; ++i) { |
||||
switch (dyn[i].d_tag) { |
||||
case DT_RELA: |
||||
rel = (Elf_Rela *)((ulong)dyn[i].d_un.d_ptr + ldbase); |
||||
break; |
||||
case DT_RELASZ: |
||||
relsz = dyn[i].d_un.d_val; |
||||
break; |
||||
case DT_RELAENT: |
||||
relent = dyn[i].d_un.d_val; |
||||
break; |
||||
default: |
||||
break; |
||||
} |
||||
} |
||||
|
||||
if (!rel && relent == 0) |
||||
return EFI_SUCCESS; |
||||
|
||||
if (!rel || relent == 0) |
||||
return EFI_LOAD_ERROR; |
||||
|
||||
while (relsz > 0) { |
||||
/* apply the relocs */ |
||||
switch (ELF_R_TYPE(rel->r_info)) { |
||||
case R_RISCV_RELATIVE: |
||||
addr = (ulong *)(ldbase + rel->r_offset); |
||||
*addr = ldbase + rel->r_addend; |
||||
break; |
||||
default: |
||||
/* Panic */ |
||||
while (1) ; |
||||
} |
||||
rel = (Elf_Rela *)((char *)rel + relent); |
||||
relsz -= relent; |
||||
} |
||||
return EFI_SUCCESS; |
||||
} |
@ -0,0 +1,65 @@ |
||||
/* SPDX-License-Identifier: GPL-2.0+ */ |
||||
/* |
||||
* (C) 2018 Alexander Graf <agraf@suse.de>
|
||||
*/ |
||||
|
||||
#include <config.h> |
||||
#include <linux/linkage.h> |
||||
|
||||
#ifdef CONFIG_CPU_RISCV_64 |
||||
#define STORE_IDX(reg, idx) sd reg, (idx*8)(a0) |
||||
#define LOAD_IDX(reg, idx) ld reg, (idx*8)(a0) |
||||
#else |
||||
#define STORE_IDX(reg, idx) sw reg, (idx*4)(a0) |
||||
#define LOAD_IDX(reg, idx) lw reg, (idx*4)(a0) |
||||
#endif |
||||
|
||||
.pushsection .text.setjmp, "ax" |
||||
ENTRY(setjmp) |
||||
/* Preserve all callee-saved registers and the SP */ |
||||
STORE_IDX(s0, 0) |
||||
STORE_IDX(s1, 1) |
||||
STORE_IDX(s2, 2) |
||||
STORE_IDX(s3, 3) |
||||
STORE_IDX(s4, 4) |
||||
STORE_IDX(s5, 5) |
||||
STORE_IDX(s6, 6) |
||||
STORE_IDX(s7, 7) |
||||
STORE_IDX(s8, 8) |
||||
STORE_IDX(s9, 9) |
||||
STORE_IDX(s10, 10) |
||||
STORE_IDX(s11, 11) |
||||
STORE_IDX(ra, 12) |
||||
STORE_IDX(sp, 13) |
||||
li a0, 0 |
||||
ret |
||||
ENDPROC(setjmp) |
||||
.popsection |
||||
|
||||
.pushsection .text.longjmp, "ax" |
||||
ENTRY(longjmp) |
||||
LOAD_IDX(s0, 0) |
||||
LOAD_IDX(s1, 1) |
||||
LOAD_IDX(s2, 2) |
||||
LOAD_IDX(s3, 3) |
||||
LOAD_IDX(s4, 4) |
||||
LOAD_IDX(s5, 5) |
||||
LOAD_IDX(s6, 6) |
||||
LOAD_IDX(s7, 7) |
||||
LOAD_IDX(s8, 8) |
||||
LOAD_IDX(s9, 9) |
||||
LOAD_IDX(s10, 10) |
||||
LOAD_IDX(s11, 11) |
||||
LOAD_IDX(ra, 12) |
||||
LOAD_IDX(sp, 13) |
||||
|
||||
/* Move the return value in place, but return 1 if passed 0. */ |
||||
beq a1, zero, longjmp_1 |
||||
mv a0, a1 |
||||
ret |
||||
|
||||
longjmp_1: |
||||
li a0, 1 |
||||
ret |
||||
ENDPROC(longjmp) |
||||
.popsection |
@ -1,19 +1,19 @@ |
||||
if TARGET_NX25_AE250 |
||||
if TARGET_AX25_AE350 |
||||
|
||||
config SYS_CPU |
||||
default "nx25" |
||||
default "ax25" |
||||
|
||||
config SYS_BOARD |
||||
default "nx25-ae250" |
||||
default "ax25-ae350" |
||||
|
||||
config SYS_VENDOR |
||||
default "AndesTech" |
||||
|
||||
config SYS_SOC |
||||
default "ae250" |
||||
default "ae350" |
||||
|
||||
config SYS_CONFIG_NAME |
||||
default "nx25-ae250" |
||||
default "ax25-ae350" |
||||
|
||||
config ENV_SIZE |
||||
default 0x2000 if ENV_IS_IN_SPI_FLASH |
@ -0,0 +1,6 @@ |
||||
AX25-AE350 BOARD |
||||
M: Rick Chen <rick@andestech.com> |
||||
S: Maintained |
||||
F: board/AndesTech/ax25-ae350/ |
||||
F: include/configs/ax25-ae350.h |
||||
F: configs/ax25-ae350_defconfig |
@ -1,6 +0,0 @@ |
||||
NX25-AE250 BOARD |
||||
M: Rick Chen <rick@andestech.com> |
||||
S: Maintained |
||||
F: board/AndesTech/nx25-ae250/ |
||||
F: include/configs/nx25-ae250.h |
||||
F: configs/nx25-ae250_defconfig |
@ -1,4 +1,4 @@ |
||||
NX25 is Andes CPU IP to adopt RISC-V architecture. |
||||
AX25 is Andes CPU IP to adopt RISC-V architecture. |
||||
|
||||
Features |
||||
======== |
@ -1,37 +0,0 @@ |
||||
// SPDX-License-Identifier: GPL-2.0+
|
||||
/*
|
||||
* (C) Copyright 2009 Faraday Technology |
||||
* Po-Yu Chuang <ratbert@faraday-tech.com> |
||||
*/ |
||||
|
||||
#include <config.h> |
||||
#include <common.h> |
||||
#include <asm/io.h> |
||||
#include <faraday/ftsmc020.h> |
||||
|
||||
struct ftsmc020_config { |
||||
unsigned int config; |
||||
unsigned int timing; |
||||
}; |
||||
|
||||
static void ftsmc020_setup_bank(unsigned int bank, struct ftsmc020_config *cfg) |
||||
{ |
||||
struct ftsmc020 *smc = (struct ftsmc020 *)CONFIG_FTSMC020_BASE; |
||||
|
||||
if (bank > 3) { |
||||
printf("bank # %u invalid\n", bank); |
||||
return; |
||||
} |
||||
|
||||
writel(cfg->config, &smc->bank[bank].cr); |
||||
writel(cfg->timing, &smc->bank[bank].tpr); |
||||
} |
||||
|
||||
void ftsmc020_init(void) |
||||
{ |
||||
struct ftsmc020_config config[] = CONFIG_SYS_FTSMC020_CONFIGS; |
||||
int i; |
||||
|
||||
for (i = 0; i < ARRAY_SIZE(config); i++) |
||||
ftsmc020_setup_bank(i, &config[i]); |
||||
} |
Loading…
Reference in new issue