Anonymous user
ARMv7-A Bare Bones: Difference between revisions
Jump to navigation
Jump to search
no edit summary
[unchecked revision] | [unchecked revision] |
mNo edit summary |
No edit summary |
||
Line 1:
{{Rating|1}}{{Kernel designs}}
In this tutorial,
Versatile Express development board for the Cortex-A15.
Line 9:
== Rationale ==
ARMv7 is likely the last purely 32-bit iteration of the ARM architecture, so
processors based on it are likely to be supported the longest. The 'A' profile is
Line 15:
most interest to OS developers.
Largely because it's the most powerful ARMv7-A processor supported by QEMU, and it
also has its own development board.
This board was designed by ARM Holdings as a prototyping board, so it makes sense
to target a relatively neutral platform built with the Cortex-A15 in mind.
Line 25:
== Toolchain ==
haven't already. The target platform is <code>arm-none-eabi</code>. You will need at
least [[GAS]], [[GCC]], and [[LD]], but it is also suggested to have [[GDB]], [[Objcopy]], and [[Objdump]].
== Code ==
Line 34 ⟶ 33:
_start.arm:
<source lang="asm">
.global _start
_start:
Line 42 ⟶ 41:
b 1b
.size _start, . - _start
</
start.c:
<
#include <stdint.h>
#define UART0_BASE 0x1c090000
void start() {
*(volatile uint32_t *)(UART0_BASE) = 'A';
}
</source>
linker.ld:
<source lang="c">
ENTRY(_start)
Line 78 ⟶ 76:
STACK_TOP = .;
}
</
== Building and Running ==
<source lang="bash">
</
== See Also ==
=== External Links ===
* [http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.subset.boards.express/index.html ARMv7 Cortex-A Series Programmer's Guide]
* [http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.ddi0406c/index.html ARMv7-A Architecture Reference Manual]
|