arm: Move libgcc assembly macros to arch/asm.h
libgcc/macros.h contains some useful assembly macros that are common in Linux kernel code and facilitate things such as unified ARM/THUMB assembly. This patch moves it to a more general place where it can be used by other code as well. Change-Id: If68e8930aaafa706c54cf9a156fac826b31bb193 Signed-off-by: Julius Werner <jwerner@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/182178 Reviewed-by: Vincent Palatin <vpalatin@chromium.org> (cherry picked from commit a780670def94a969829811fa8cf257f12b88f085) Signed-off-by: Isaac Christensen <isaac.christensen@se-eng.com> Reviewed-on: http://review.coreboot.org/6917 Tested-by: build bot (Jenkins) Reviewed-by: David Hendricks <dhendrix@chromium.org>
This commit is contained in:
parent
406bad127b
commit
64b9ca9d4e
9 changed files with 122 additions and 43 deletions
|
@ -27,17 +27,16 @@
|
|||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
.global _entry, _leave
|
||||
.text
|
||||
.align 4
|
||||
#include <arch/asm.h>
|
||||
|
||||
1:
|
||||
.align 4
|
||||
.word _stack
|
||||
|
||||
/*
|
||||
* Our entry point
|
||||
*/
|
||||
_entry:
|
||||
ENTRY(_entry)
|
||||
|
||||
/* TODO: disable interrupts */
|
||||
|
||||
|
@ -46,14 +45,15 @@ _entry:
|
|||
/* Setup new stack */
|
||||
ldr sp, 1b
|
||||
|
||||
/* TODO: Save old stack pointer */
|
||||
/* TODO: Save old stack pointer and link register */
|
||||
|
||||
/* Let's rock. */
|
||||
b start_main
|
||||
bl start_main
|
||||
|
||||
/* %eax has the return value - pass it on unmolested */
|
||||
_leave:
|
||||
/* TODO: restore old stack pointer. */
|
||||
/* %r0 has the return value - pass it on unmolested */
|
||||
|
||||
/* TODO: restore old stack pointer and link register */
|
||||
|
||||
/* Return to the original context. */
|
||||
mov pc, lr
|
||||
bx lr
|
||||
ENDPROC(_entry)
|
||||
|
|
|
@ -27,11 +27,9 @@
|
|||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
.global halt
|
||||
.text
|
||||
.align 4
|
||||
#include <arch/asm.h>
|
||||
|
||||
/* This function puts the system into a halt. */
|
||||
.type halt, function
|
||||
halt:
|
||||
ENTRY(halt)
|
||||
b halt
|
||||
ENDPROC(halt)
|
||||
|
|
47
payloads/libpayload/include/arm/arch/asm.h
Normal file
47
payloads/libpayload/include/arm/arch/asm.h
Normal file
|
@ -0,0 +1,47 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright 2013 Google Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#ifndef __ARM_ASM_H
|
||||
#define __ARM_ASM_H
|
||||
|
||||
#if defined __arm__
|
||||
# define ARM(x...) x
|
||||
# define THUMB(x...)
|
||||
#elif defined __thumb__
|
||||
# define ARM(x...)
|
||||
# define THUMB(x...) x
|
||||
#else
|
||||
# error Not in ARM or thumb mode!
|
||||
#endif
|
||||
|
||||
#define ALIGN .align 0
|
||||
|
||||
#define ENDPROC(name) \
|
||||
.type name, %function; \
|
||||
END(name)
|
||||
|
||||
#define ENTRY(name) \
|
||||
.globl name; \
|
||||
ALIGN; \
|
||||
name:
|
||||
|
||||
#define END(name) \
|
||||
.size name, .-name
|
||||
|
||||
#endif /* __ARM_ASM_H */
|
|
@ -19,7 +19,8 @@
|
|||
##
|
||||
###############################################################################
|
||||
|
||||
armv4_flags = -marm -march=armv4t -I$(src)/arch/arm/include/armv4/
|
||||
armv4_flags = -marm -march=armv4t -I$(src)/arch/arm/include/armv4/ \
|
||||
-D__COREBOOT_ARM_ARCH__=4
|
||||
|
||||
###############################################################################
|
||||
# bootblock
|
||||
|
|
|
@ -29,19 +29,10 @@
|
|||
* MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
#include <arch/asm.h>
|
||||
|
||||
.section ".start", "a", %progbits
|
||||
.globl _start
|
||||
_start: b reset
|
||||
.balignl 16,0xdeadbeef
|
||||
|
||||
_cbfs_master_header:
|
||||
/* The CBFS master header is inserted by cbfstool at the first
|
||||
* aligned offset after the above anchor string is found.
|
||||
* Hence, we leave some space for it.
|
||||
*/
|
||||
.skip 128 @ Assumes 64-byte alignment
|
||||
|
||||
reset:
|
||||
ENTRY(_start)
|
||||
/*
|
||||
* Set the cpu to System mode with IRQ and FIQ disabled. Prefetch/Data
|
||||
* aborts may happen early and crash before the abort handlers are
|
||||
|
@ -84,6 +75,7 @@ call_bootblock:
|
|||
* wrapper which is currently broken.
|
||||
*/
|
||||
bl main
|
||||
ENDPROC(_start)
|
||||
|
||||
/* we do it this way because it's a 32-bit constant and
|
||||
* in some cases too far away to be loaded as just an offset
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
###############################################################################
|
||||
|
||||
armv7_flags = -march=armv7-a -mthumb -mthumb-interwork \
|
||||
-I$(src)/arch/arm/include/armv7/
|
||||
-I$(src)/arch/arm/include/armv7/ -D__COREBOOT_ARM_ARCH__=7
|
||||
|
||||
###############################################################################
|
||||
# bootblock
|
||||
|
|
|
@ -29,9 +29,10 @@
|
|||
* MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
#include <arch/asm.h>
|
||||
|
||||
.section ".start", "a", %progbits
|
||||
.globl _start
|
||||
_start:
|
||||
ENTRY(_start)
|
||||
/*
|
||||
* Set the cpu to System mode with IRQ and FIQ disabled. Prefetch/Data
|
||||
* aborts may happen early and crash before the abort handlers are
|
||||
|
@ -89,6 +90,7 @@ call_bootblock:
|
|||
wait_for_interrupt:
|
||||
wfi
|
||||
mov pc, lr @ back to my caller
|
||||
ENDPROC(_start)
|
||||
|
||||
/* we do it this way because it's a 32-bit constant and
|
||||
* in some cases too far away to be loaded as just an offset
|
||||
|
|
47
src/arch/arm/include/arch/asm.h
Normal file
47
src/arch/arm/include/arch/asm.h
Normal file
|
@ -0,0 +1,47 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright 2013 Google Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
#ifndef __ARM_ASM_H
|
||||
#define __ARM_ASM_H
|
||||
|
||||
#if defined __arm__
|
||||
# define ARM(x...) x
|
||||
# define THUMB(x...)
|
||||
#elif defined __thumb__
|
||||
# define ARM(x...)
|
||||
# define THUMB(x...) x
|
||||
#else
|
||||
# error Not in ARM or thumb mode!
|
||||
#endif
|
||||
|
||||
#define ALIGN .align 0
|
||||
|
||||
#define ENDPROC(name) \
|
||||
.type name, %function; \
|
||||
END(name)
|
||||
|
||||
#define ENTRY(name) \
|
||||
.globl name; \
|
||||
ALIGN; \
|
||||
name:
|
||||
|
||||
#define END(name) \
|
||||
.size name, .-name
|
||||
|
||||
#endif /* __ARM_ASM_H */
|
|
@ -29,19 +29,10 @@
|
|||
* MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
#include <arch/asm.h>
|
||||
|
||||
.section ".start", "a", %progbits
|
||||
.globl _start
|
||||
_start: b reset
|
||||
.balignl 16,0xdeadbeef
|
||||
|
||||
_cbfs_master_header:
|
||||
/* The CBFS master header is inserted by cbfstool at the first
|
||||
* aligned offset after the above anchor string is found.
|
||||
* Hence, we leave some space for it.
|
||||
*/
|
||||
.skip 128 @ Assumes 64-byte alignment
|
||||
|
||||
reset:
|
||||
ENTRY(_start)
|
||||
/*
|
||||
* Set the cpu to System mode with IRQ and FIQ disabled. Prefetch/Data
|
||||
* aborts may happen early and crash before the abort handlers are
|
||||
|
@ -84,6 +75,7 @@ call_bootblock:
|
|||
* wrapper which is currently broken.
|
||||
*/
|
||||
bl main
|
||||
ENDPROC(_start)
|
||||
|
||||
/* we do it this way because it's a 32-bit constant and
|
||||
* in some cases too far away to be loaded as just an offset
|
||||
|
|
Loading…
Reference in a new issue