[LINUX] ARM-Architektur »Portierung

Ursprünglich ist es Teil des Quellcodes des Linux-Kernels, daher wird es als GPLv2 behandelt (Anerkennung, dass es sein sollte).

https://www.kernel.org/doc/html/latest/index.html

Licensing documentation

The following describes the license of the Linux kernel source code (GPLv2), how to properly mark the license of individual files in the source tree, as well as links to the full license text.

https://www.kernel.org/doc/html/latest/process/license-rules.html#kernel-licensing

https://www.kernel.org/doc/html/latest/arm/porting.html


Porting

Taken from list archive at http://lists.arm.linux.org.uk/pipermail/linux-arm-kernel/2001-July/004064.html

Initial definitions

The following symbol definitions rely on you knowing the translation that __virt_to_phys() does for your machine. This macro converts the passed virtual address to a physical address. Normally, it is simply:

Bei den folgenden Symboldefinitionen wird davon ausgegangen, dass Sie die Konvertierung kennen, die __virt_to_phys () für Ihren Computer ausführt. Dieses Makro übersetzt die übergebene virtuelle Adresse in eine physische Adresse. Normalerweise ist es einfach:

phys = virt - PAGE_OFFSET + PHYS_OFFSET

Decompressor Symbols

ZTEXTADDR

Start address of decompressor. There’s no point in talking about virtual or physical addresses here, since the MMU will be off at the time when you call the decompressor code. You normally call the kernel at this address to start it booting. This doesn’t have to be located in RAM, it can be in flash or other read-only or read-write addressable medium.

Die Startadresse des Dekompressors. Es spielt keine Rolle, ob es sich um eine virtuelle oder eine physische Adresse handelt, aber die MMU ist ausgeschaltet, wenn der Dekomprimierungscode aufgerufen wird. Normalerweise ruft der Kernel diese Adresse auf, wenn er mit dem Booten beginnt. Es muss kein RAM sein, es kann sich um Flash oder ein anderes schreibgeschütztes Lese- / Schreibmedium handeln.

ZBSSADDR

Start address of zero-initialised work area for the decompressor. This must be pointing at RAM. The decompressor will zero initialise this for you. Again, the MMU will be off.

Die Arbeitsspeicher-Startadresse, die für den Dekomprimierer mit 0 initialisiert wird. Es muss im RAM sein. Der Dekomprimierer initialisiert dies mit 0. Auch hier muss die MMU ausgeschaltet sein.

ZRELADDR

This is the address where the decompressed kernel will be written, and eventually executed. The following constraint must be valid:

Die Adresse, unter der der dekomprimierte Kernel geschrieben und ausgeführt wird. Dies muss die folgenden Einschränkungen erfüllen:

__virt_to_phys(TEXTADDR) == ZRELADDR

The initial part of the kernel is carefully coded to be position independent.

Der Initialisierungsteil des Kernels wird sorgfältig für positionsunabhängigen Code codiert.

INITRD_PHYS

Physical address to place the initial RAM disk. Only relevant if you are using the bootpImage stuff (which only works on the old struct param_struct).

Anfangs-RAM Die physikalische Adresse, an der sich die Festplatte befindet. Nur relevant, wenn Sie bootpImage verwenden (funktioniert nur mit der alten Struktur param_struct).

INITRD_VIRT

Virtual address of the initial RAM disk. The following constraint must be valid:

anfänglicher RAM Die virtuelle Adresse, an der sich die Festplatte befindet. Dies muss die folgenden Einschränkungen erfüllen:

__virt_to_phys(INITRD_VIRT) == INITRD_PHYS

PARAMS_PHYS

Physical address of the struct param_struct or tag list, giving the kernel various parameters about its execution environment.

Die physikalische Adresse der param_struct-Struktur oder der Tag-Liste, die dem Kernel verschiedene Parameter für den Abschluss der Ausführung bereitstellt.

Kernel Symbols

PHYS_OFFSET

Physical start address of the first bank of RAM.

Die physikalische Adresse, an der die erste RAM-Bank beginnt.

PAGE_OFFSET

Virtual start address of the first bank of RAM. During the kernel boot phase, virtual address PAGE_OFFSET will be mapped to physical address PHYS_OFFSET, along with any other mappings you supply. This should be the same value as TASK_SIZE.

Die virtuelle Adresse, an der die erste RAM-Bank startet. Während der Startphase des Kernels wird die virtuelle Adresse PAGE_OFFSET zusammen mit anderen benutzerdefinierten Zuordnungen der physischen Adresse PHTS_OFFSET zugeordnet. Dies sollte der gleiche Wert wie TASK_SIZE sein.

TASK_SIZE

The maximum size of a user process in bytes. Since user space always starts at zero, this is the maximum address that a user process can access+1. The user space stack grows down from this address.

Maximale Größe des Benutzerprozesses in Byte. Der Benutzerbereich beginnt immer bei 0, daher ist dies die Adresse +1, auf die der Benutzerprozess zugreifen kann. Der User Space Stack wächst von dieser Adresse aus.

Any virtual address below TASK_SIZE is deemed to be user process area, and therefore managed dynamically on a process by process basis by the kernel. I’ll call this the user segment.

Virtuelle Adressen, die kleiner als TASK_SIZE sind, werden als Bereich des Benutzerprozesses betrachtet und vom Kernel pro Prozess dynamisch verwaltet. Dies wird als Benutzersegment bezeichnet.

Anything above TASK_SIZE is common to all processes. I’ll call this the kernel segment.

Alles, was TASK_SIZE überschreitet, ist allen Prozessen gemeinsam. Dies wird als Kernelsegment bezeichnet.

(In other words, you can’t put IO mappings below TASK_SIZE, and hence PAGE_OFFSET).

(Mit anderen Worten, die E / A-Zuordnung kann nicht nach TASK_SIZE platziert werden, daher sollte sie nach PAGE_OFFSET platziert werden.)

TEXTADDR

Virtual start address of kernel, normally PAGE_OFFSET + 0x8000. This is where the kernel image ends up. With the latest kernels, it must be located at 32768 bytes into a 128MB region. Previous kernels placed a restriction of 256MB here.

Die Startadresse des Kernels im virtuellen Raum, normalerweise PAGE_OFFSET + 0x8000. Dies ist die endgültige Position des Kernel-Images. In modernen Kerneln sollte es in einem Bereich von 32768 Bytes bis 128 MB liegen. Der traditionelle Kernel hat ein Limit von 256 MB.

DATAADDR

Virtual address for the kernel data segment. Must not be defined when using the decompressor.

Die virtuelle Adresse des Kernel-Datensegments. Wenn Sie einen Dekomprimierer verwenden, definieren Sie ihn nicht.

VMALLOC_START / VMALLOC_END

Virtual addresses bounding the vmalloc() area. There must not be any static mappings in this area; vmalloc will overwrite them. The addresses must also be in the kernel segment (see above). Normally, the vmalloc() area starts VMALLOC_OFFSET bytes above the last virtual RAM address (found using variable high_memory).

Die virtuelle Adresse, die an den Bereich vmalloc () grenzt. In diesem Bereich sollte keine statische Zuordnung vorhanden sein. vmalloc überschreibt sie. Die Adresse muss auch im Kernelsegment (oben) enthalten sein. Der Bereich vmalloc () beginnt normalerweise bei VMALLOC_OFFSET-Bytes und befindet sich am Ende der RAM-Adresse der virtuellen Adresse (ermittelt mit der Variablen high_memory).

VMALLOC_OFFSET Offset normally incorporated into VMALLOC_START to provide a hole between virtual RAM and the vmalloc area. We do this to allow out of bounds memory accesses (eg, something writing off the end of the mapped memory map) to be caught. Normally set to 8MB.

Architecture Specific Macros

BOOT_MEM(pram,pio,vio)

pram specifies the physical start address of RAM. Must always be present, and should be the same as PHYS_OFFSET.

Kinderwagen gibt die physische Startadresse des RAM an. Muss immer vorhanden sein und muss mit PHYS_OFFSET identisch sein.

pio is the physical address of an 8MB region containing IO for use with the debugging macros in arch/arm/kernel/debug-armv.S.

pio ist die physische Adresse des 8-MB-Bereichs, der die vom Debug-Makro in arch / arm / kernel / debug-armv.S verwendete E / A enthält.

vio is the virtual address of the 8MB debugging region.

vio ist die virtuelle Adresse des 8-MB-Debug-Bereichs.

It is expected that the debugging region will be re-initialised by the architecture specific code later in the code (via the MAPIO function).

Es wird erwartet, dass der Debug-Bereich später im Code durch den architekturspezifischen Code (über die MAPIO-Funktion) neu initialisiert wird.

BOOT_PARAMS

Same as, and see PARAMS_PHYS.

Bitte beziehen Sie sich darauf, da es mit PARAMS_PHYS identisch ist.

FIXUP(func)

Machine specific fixups, run before memory subsystems have been initialised.

Maschinenspezifischer Korrekturprozess. Es wird ausgeführt, bevor die Speichersubsysteme initialisiert werden.

MAPIO(func)

Machine specific function to map IO areas (including the debug region above).

Maschinenspezifische E / A-Bereichszuordnungsfunktion (einschließlich der oben genannten Debug-Region)

INITIRQ(func)

Machine specific function to initialise interrupts.

Maschinenspezifische anfängliche Interrupt-Funktion.

Recommended Posts

ARM-Architektur »Portierung
Portieren von MicroPython
Führen Sie Linux mit ARM-Architektur mit QEMU aus