Page MenuHomeFreeBSD

Add EFI RT support for arm64
ClosedPublic

Authored by andrew on Oct 5 2017, 11:52 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 3, 9:18 PM
Unknown Object (File)
Fri, Nov 29, 8:52 PM
Unknown Object (File)
Nov 19 2024, 1:59 AM
Unknown Object (File)
Nov 18 2024, 6:17 AM
Unknown Object (File)
Nov 15 2024, 6:13 AM
Unknown Object (File)
Nov 5 2024, 9:19 PM
Unknown Object (File)
Oct 4 2024, 9:27 AM
Unknown Object (File)
Oct 3 2024, 10:36 PM
Subscribers

Details

Summary

Support the EFI Runtime Services on arm64. As with amd64 we use the 1:1
mapping. This uses the new common code shared with amd64.

The RTC should only be accessed via EFI. There is no locking around it as
the spec only has this as a requirement for the PC-AT CMOS device.

Test Plan

Tested on ThunderX with an EDK based UEFI. Will need testing with U-Boot.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 11958
Build 12285: arc lint + arc unit

Event Timeline

This revision is now accepted and ready to land.Oct 5 2017, 1:17 PM
sys/arm64/include/fpu.h
2

Need headers on this file. I'd recommend the public domain one because it's just a single #include.

sys/modules/Makefile
708–710

This is super ugly. Any chance you can define _efirt twice: once in the amd64 section and once in the aarch64 section? And really, that should be MACHINE == arm64 (there are many mistakes like this in this file, some introduced by me).

  • Add a public domain comment to fpu.h
  • Move _efirt to an aarch64 specific section in modules/Makefile
This revision now requires review to proceed.Oct 8 2017, 1:55 PM

I didn't check that all the MMU stuff was right, but the rest looks good now. thanks for fixing.

sys/arm64/arm64/machdep.c
995

I thought that there were extensions to efi to return FDT. Does it not make sense to grab it before we try to load dtb? Or is that detail handled in the boot loader?

This revision is now accepted and ready to land.Oct 8 2017, 2:41 PM
sys/arm64/arm64/machdep.c
995

We grab the dtb in the boot loader, then copy it to be just after before the module data.

This revision was automatically updated to reflect the committed changes.