[A quick top post about synchronous aborts for aarch64.] http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.den0024a/ch10s02s01.html says:
> Synchronous exceptions can occur for a number of possible reasons: > > • Aborts from the MMU. For example, permission failures or memory areas > marked as Access flag fault. > • SP and PC alignment checking. > • Unallocated instructions. > • Service Calls (SVCs, SMCs and HVCs). > > Such exceptions may be part of the normal operation of the OS. For example, > in Linux, when a task wishes to request allocation of a new memory page, this > is handled through the MMU abort mechanism. > > In the ARMv7-A architecture, the prefetch abort, Data Abort and undef > exceptions are separate items. In AArch64, all of these events generate a > Synchronous abort. The exception handler may then read the syndrome and FAR > registers to obtain the necessary information to distinguish between them > (described in more detail later.) === Mark Millard markmi at dsl-only.net On 2016-Oct-17, at 2:11 PM, Shawn Webb <shawn.webb at hardenedbsd.org> wrote: Hey All, I'm submitting this report to this list as directed by Ed Maste. The Raspberry Pi 3 is an ARMv8 SoC dev board. Within the last week, FreeBSD added basic initial support for it. We don't currently have a linker in HEAD for the arm64/aarch64 platform. The projects/clang390-import branch contains lld, though, which supports arm64/aarch64. Over the past few days, I've been working on testing clang 3.9.0 and lld on the RPI3. I've jotted down a few issues in FreeBSD's wiki: https://wiki.freebsd.org/arm64/rpi3 Mainly: low-level code like bootloaders (boot1.efi and loader.efi) do NOT work with projects/clang390-import. When I use boot1.efi and loader.efi compiled with HEAD (clang 3.8), they work. When the kernel is compiled with clang 3.9.0, it seems to freeze after being loaded by the clang 3.8 boot1.efi/loader.efi. I'm unsure if it's actually frozen or if simply nothing is being outputted to the console. Either way, I don't see console messages and the RPI3 _appears_ frozen. I'm tracking down a potential issue with jemalloc compiled with clang 3.9.0, but I need to verify that the issue exists in vanilla FreeBSD in addition to HardenedBSD. Most of my testing has been done with HardenedBSD to-date. If I find more issues or find the causes of the ones I've already documented, I'll be sure to not only update the wiki, but update this email thread as well. If there's anything anyone would like me to try, please let me know. Thanks, -- Shawn Webb Cofounder and Security Engineer HardenedBSD GPG Key ID: 0x6A84658F52456EEE GPG Key Fingerprint: 2ABA B6BD EF6A F486 BE89 3D9E 6A84 658F 5245 6EEE _______________________________________________ freebsd-toolchain@freebsd.org mailing list https://lists.freebsd.org/mailman/listinfo/freebsd-toolchain To unsubscribe, send any mail to "freebsd-toolchain-unsubscr...@freebsd.org"