SlideShare ist ein Scribd-Unternehmen logo
1 von 28
Downloaden Sie, um offline zu lesen
Linux Porting
for new ARM platform

Champ Yen
http://champyen.blogspot.com
champ.yen@gmail.com
OutLine

GNU Toolchain
Linux Kernel Prerequisites and Assumptions
Images
Boot Sequence
Kernel Configuration & Compilation
Kernel Porting
Device Drivers
Boot Options
initramfs vs initrd
References
GNU Toolchains

   CodeSourcery gnu toolchain
    http://www.codesourcery.com/sgpp/lite/arm/download.html
   Buildroot
    http://buildroot.uclibc.org/
   Scratchbox
    http://www.scratchbox.org/
   OpenEmbedded
    http://wiki.openembedded.net/index.php/Main_Page
   Ptxdist
    http://www.pengutronix.de/software/ptxdist/index_en.html
GNU Toolchains - buildroot
   linux kernel like configuration interface
    ncurse UI, .config file
   uClibc generate linux 2.6 compatible small footprint
    applications
   for most platform remember to enable software float
   output: toolchain/uClibc/busybox/rootfs
Linux Kernel Prerequisites and Assumptions


   DRAM is initialized
   Hardware-related initialization tasks are done
   MMU/Cache is disabled
   specific values should be saved in registers
    r1: Machine ID, r2: pointer of ATAG list (optional)
Images and intermediate files




                                                                       piggy.o
                             image
  vmlinuz       objcopy      (binary    gzip     piggy.gz      asm
 (ELF object)                 object)
                                                                        misc.o

                                               compressed              head.o
                          stripped image       binary kernel
                           binary kernel                               bootable
                                                                     kernel image
kernel proper                                                          (zImage)
Boot Sequence


   start

       arch/arm/boot/   start
        compressed/
          head.S                              start_kernel
                           arch/arm/kernel/
                               head.S

    bootstrap loader                               init/main.c
     (uncompress)
                          ARM-specific
                           kernel code
                                                 kernel code




detail boot sequence is listed in [9]
Kernel Porting – Kernel Memory Map

                                                     0xFFFF_FFFF
CPU vector page/copy_user_page(),clear_user_page()

                                                     0xFFFF_0000
          DMA memory mapping
                                                     0xFF00_0000
           free for platform use
                                                     VMALLOC_END
        vmalloc()/ioremap() space
                                                     VMALLOC_START
   kernel direct-mapped RAM region
                                                     PAGE_OFFSET
           kernel module space
                                                     TASK_SIZE
           user space mapping
                                                     0x0000_1000
   CPU vector page/null pointer trap
                                                     0x0000_0000
Kernel Porting – Directories

   mm/
    memory-handling related code
   boot/
    bootstrap loader code
   kernel/
    ARM architecture dependent code
   mach-XXXXXX/
    specific machine dependent code
   configs/
    each machine’s default kernel configurations
Kernel Porting – new machine items

refer to other machine to create or modify items(ex: foo, fxx)
  register the new machine
    arch/arm/tools/mach-types
   Create machine folder
    arch/arm/mach-fxx
    arch/arm/mach-fxx/include/mach
   Modify or Create Kconfig & Makefile
    arch/arm/Kconfig (usually add config ARCH_FXX for architecture)
    arch/arm/Makefile
    arch/arm/mm/Kconfig
    arch/arm/mach-fxx/Kconfig (config MACH_FOO for machine)
    arch/arm/mach-fxx/Makefile
    arch/arm/mach-fxx/Makefile.boot (set zreladdr-y for image location)
Kernel Porting – new machine items
        register the new machine


   Add an entry in arch/arm/tools/mach-types
    ex: foo MACH_FOO FOO                65535
   For official registration, should register here, also.
    http://www.arm.linux.org.uk/developer/machines/
Kernel Porting – new machine items
        create machine folders


     arm/arch/mach-fxx
      for machine dependent source code
     arm/arm/mach-fxx/include/mach
      for machine dependent headers/assembly

debug-macro.S: adduart, senduart, busyuart, waituart
dma.h
entry-macro.S: macro get_irqnr_and_base
hardware.h                        system.h: arch_idle(), arch_reset()
io.h                              timex.h: CLOCK_TICK_RATE
irqs.h: NR_IRQS                   uncompress.h: putc()
memory.h: PHYS_OFFSET             vmalloc.h: VMALLOC_END
Kernel Porting – new machine items
        modify or create Kconfig & Makefile

   arch/arm/Kconfig
    config ARCH_FXX
       bool “FXX family processors“
       help
         This enables support for systems based on the fxx processors.
    ………
    source "arch/arm/mach-fxx/Kconfig"
   arch/arm/Makefile
    machine-$(CONFIG_ARCH_FXX)        := fxx
   arch/arm/mm/Kconfig (ex: ARM926-based)
    config CPU_ARM926T
         bool "Support ARM926T processor"
          depends on ARCH_INTEGRATOR || ARCH_VERSATILE_PB || 
                   … || ARCH_FXX
          default y if ARCH_VERSATILE_PB || ARCH_VERSATILE_AB || 
                   … || ARCH_FXX
Kernel Porting – new machine items
        modify or create Kconfig & Makefile

   arch/arm/mach-fxx/Kconfig
    menu "FXX platform type“
     depends on ARCH_FXX
    config MACH_FOO
      bool "Support FOO platform"
      default y
      help
    Include support for the FOO platform.
    endmenu
   arch/arm/mach-fxx/Makefile
    # Common support (must be linked before board specific support)
    obj-y :=                                                    architecture depend code
    # Specific board support
    obj-$(CONFIG_MACH_FOO) += core.o                            machine depend code
   arch/arm/mach-fxx/Makefile.boot
    zreladdr-y := 0x01008000
Kernel Porting – description structure

MACHINE_START(FOO, "FOO processor")
   /* Maintainer: Champ Yen */
   .map_io = foo_map_io,
   .init_irq = foo_init_irq,
   .init_machine = foo_init,
   .timer = &foo_timer,
   /* for ATAG list is optional */
   .boot_params = 0x01000100,
MACHINE_END
Kernel Porting – Initialization code

   I/O Memory Mapping Table
   IRQ
   Timer
    struct sys_timer
   Initial order: .map_io .initrq .timer .init_machine
Kernel Porting – I/O Memory Map

static struct map_desc foo_io_desc[] __initdata =
{
     {
     /* address after mapping */
     .virtual       = IO_ADDRESS(CPU_DEV_PHY_BASE),
     /* page index of physical address */
     .pfn = __phys_to_pfn(CPU_DEV_PHY_BASE),
     .length        = CPU_DEV_IO_LEN,             /* address mapping range */
     .type          = MT_DEVICE        /* I/O type */
     },
    ……
};
….
static void __init foo_map_io(void)
{
     iotable_init(foo_io_desc, ARRAY_SIZE(foo_io_desc));
}
Kernel Porting – IRQ

       arch/arm/mach-fxx/include/mach/entry-macro.S
        get_irqnr_and_base: after calling irqnr: irq number, not equal
        condition should be set.
       arch/arm/mach-fxx/include/mach/irqs.h
        NR_IRQS (number of irq types) should be defined
       struct irq_chip, irqaction
        set_irq_chip(), set_irq_flags(), set_irq_handler(), setup_irq()

                                          ………
static struct irq_chip foo_irq_chip = {
                                          for(i = o; i < NR_IRQS; i++){
      .ack = foo_int_ack,
                                                       set_irq_handler(i, handle_level_irq);
      .mask = foo_int_mask,
                                                       set_irq_chip(i, &foo_irq_chip);
      .unmask = foo_int_unmask,
                                                       set_irq_flags(i, IRQF_VALID);
};
                                          }
                                          ………
Kernel Porting - Timer


struct sys_timer foo_timer = {
     .init      = foo_timer_init,
     .offset      = foo_gettimeoffset,
};
Kernel Porting – DMA memory (optional)


   Influence to dma_alloc_coherent() usage
   In arch/arm/mach-fxx/include/mach/dma.h
      MAX_DMA_ADDRESS


   In arch/arm/mach-fxx/include/mach/memory.h
      CONSISTENT_DMA_SIZE


       ISA_DMA_THRESHOLD
Boot Options – static string

   Boot options -> Default kernel command string
    ex: mem=8M@0x01000000 initrd=0x01180000,145762
Boot Options – ATAG lists

   ATAG provides dynamic boot option passing
   There are two way to pass pointer of ATAG lists
    r2 value passed by bootloader, .boot_params in machine descriptor
   refer to arch/arm/include/asm/setup.h

      struct tag_header {
           __u32 size;                                           ATAG_CORE
           __u32 tag;
      };




                                                                        ……
      struct tag {
           struct tag_header hdr;
           union {
                 struct tag_core    core;
                 struct tag_mem32     mem;
                 …
           } u;                                                  ATAG_NONE
      };
Device Drivers

   platform_device_register(), platform_driver_register()
    for some on-chip devices(ex: clock/power control)
   UART subsystem in driver/serial
    for startup message, console ,and shell
   Framebuffer subsystem in driver/video
initramfs vs initrd

                  initrd               initramfs
image             ext2 image + gzip    cpio + gzip
implementation block device            tmpfs
first execution   /linuxrc             /init
mount rootfs      pivot_root           switch_root

initrd requires ext2 and block devices support. It adds 150KB+
to kernel size.
initramfs

   create an initramfs image by command:
    find . | cpio -o -H newc | gzip > ../initramfs.cpio.gz

   take care of the distance between image and kernel,
    otherwise image will be overwritten by kernel.
   /init
    ex:
    #!/bin/busybox sh
    #/bin/busybox --install
    mount -t proc proc /proc
    exec /bin/busybox sh
Debug

   decompression: putc() definiition in include/mach/uncompress.h
   kernel debugging features in kernel hacking of kernel options (and
    CONFIG_DEBUG_LL option for low level debugging)
   early debug: printascii/printhex(2,4,8) make use of uart macros in
    include/mach/debug-macro.S
   printk()
   CONNFIG_KGDB
References

   Embedded Linux Primer, Christopher Hallinan, Prentice Hall
   Building Embedded Linux Systems 2/e, Karim Yaghmour, Oreilly
   linux-2.6.2x-xx/Documentation/arm
   http://heaven.branda.to/~thinker/GinGin_CGI.py/get_afile/166/porting_to_arm.pdf
   http://www.glomationinc.com/PortingLinuxKernel.pdf
   http://www.ens-lyon.fr/LIP/Pub/Rapports/RR/RR2006/RR2006-08.pdf
   http://glt08.linuxtage.at/slides/glt08-kvas_linuxonarm.pdf
   http://www.linux-arm.org/LinuxKernel/LinuxNewPlatformPort
   http://gicl.cs.drexel.edu/people/sevy/linux/ARM_Linux_boot_sequence.html
   http://www.simtec.co.uk/products/SWLINUX/files/booting_article.html
   http://www.ibm.com/developerworks/linux/library/l-initrd.html
   http://blog.linux.org.tw/~jserv/archives/001954.html
Q&A

Weitere ähnliche Inhalte

Was ist angesagt?

Linux Initialization Process (2)
Linux Initialization Process (2)Linux Initialization Process (2)
Linux Initialization Process (2)shimosawa
 
Part 02 Linux Kernel Module Programming
Part 02 Linux Kernel Module ProgrammingPart 02 Linux Kernel Module Programming
Part 02 Linux Kernel Module ProgrammingTushar B Kute
 
Linux Kernel Booting Process (1) - For NLKB
Linux Kernel Booting Process (1) - For NLKBLinux Kernel Booting Process (1) - For NLKB
Linux Kernel Booting Process (1) - For NLKBshimosawa
 
Trusted firmware deep_dive_v1.0_
Trusted firmware deep_dive_v1.0_Trusted firmware deep_dive_v1.0_
Trusted firmware deep_dive_v1.0_Linaro
 
U Boot or Universal Bootloader
U Boot or Universal BootloaderU Boot or Universal Bootloader
U Boot or Universal BootloaderSatpal Parmar
 
Page cache in Linux kernel
Page cache in Linux kernelPage cache in Linux kernel
Page cache in Linux kernelAdrian Huang
 
XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...
XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...
XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...The Linux Foundation
 
linux device driver
linux device driverlinux device driver
linux device driverRahul Batra
 
Vmlinux: anatomy of bzimage and how x86 64 processor is booted
Vmlinux: anatomy of bzimage and how x86 64 processor is bootedVmlinux: anatomy of bzimage and how x86 64 processor is booted
Vmlinux: anatomy of bzimage and how x86 64 processor is bootedAdrian Huang
 
Bootstrap process of u boot (NDS32 RISC CPU)
Bootstrap process of u boot (NDS32 RISC CPU)Bootstrap process of u boot (NDS32 RISC CPU)
Bootstrap process of u boot (NDS32 RISC CPU)Macpaul Lin
 
Device tree support on arm linux
Device tree support on arm linuxDevice tree support on arm linux
Device tree support on arm linuxChih-Min Chao
 

Was ist angesagt? (20)

Linux Initialization Process (2)
Linux Initialization Process (2)Linux Initialization Process (2)
Linux Initialization Process (2)
 
Part 02 Linux Kernel Module Programming
Part 02 Linux Kernel Module ProgrammingPart 02 Linux Kernel Module Programming
Part 02 Linux Kernel Module Programming
 
Linux Kernel Booting Process (1) - For NLKB
Linux Kernel Booting Process (1) - For NLKBLinux Kernel Booting Process (1) - For NLKB
Linux Kernel Booting Process (1) - For NLKB
 
Trusted firmware deep_dive_v1.0_
Trusted firmware deep_dive_v1.0_Trusted firmware deep_dive_v1.0_
Trusted firmware deep_dive_v1.0_
 
Embedded Linux on ARM
Embedded Linux on ARMEmbedded Linux on ARM
Embedded Linux on ARM
 
Linux Internals - Interview essentials 4.0
Linux Internals - Interview essentials 4.0Linux Internals - Interview essentials 4.0
Linux Internals - Interview essentials 4.0
 
Linux Booting Steps
Linux Booting StepsLinux Booting Steps
Linux Booting Steps
 
U Boot or Universal Bootloader
U Boot or Universal BootloaderU Boot or Universal Bootloader
U Boot or Universal Bootloader
 
Linux scheduler
Linux schedulerLinux scheduler
Linux scheduler
 
Linux Internals - Interview essentials - 1.0
Linux Internals - Interview essentials - 1.0Linux Internals - Interview essentials - 1.0
Linux Internals - Interview essentials - 1.0
 
Page cache in Linux kernel
Page cache in Linux kernelPage cache in Linux kernel
Page cache in Linux kernel
 
XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...
XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...
XPDS13: Xen in OSS based In–Vehicle Infotainment Systems - Artem Mygaiev, Glo...
 
linux device driver
linux device driverlinux device driver
linux device driver
 
Vmlinux: anatomy of bzimage and how x86 64 processor is booted
Vmlinux: anatomy of bzimage and how x86 64 processor is bootedVmlinux: anatomy of bzimage and how x86 64 processor is booted
Vmlinux: anatomy of bzimage and how x86 64 processor is booted
 
Making Linux do Hard Real-time
Making Linux do Hard Real-timeMaking Linux do Hard Real-time
Making Linux do Hard Real-time
 
Linux Porting
Linux PortingLinux Porting
Linux Porting
 
Bootstrap process of u boot (NDS32 RISC CPU)
Bootstrap process of u boot (NDS32 RISC CPU)Bootstrap process of u boot (NDS32 RISC CPU)
Bootstrap process of u boot (NDS32 RISC CPU)
 
Linux device drivers
Linux device drivers Linux device drivers
Linux device drivers
 
BusyBox for Embedded Linux
BusyBox for Embedded LinuxBusyBox for Embedded Linux
BusyBox for Embedded Linux
 
Device tree support on arm linux
Device tree support on arm linuxDevice tree support on arm linux
Device tree support on arm linux
 

Andere mochten auch

Mainline U-BOOT for iMX6 (AR6MX)
Mainline U-BOOT for iMX6 (AR6MX)Mainline U-BOOT for iMX6 (AR6MX)
Mainline U-BOOT for iMX6 (AR6MX)Frodo Lai
 
Linux fundamental - Chap 11 boot
Linux fundamental - Chap 11 bootLinux fundamental - Chap 11 boot
Linux fundamental - Chap 11 bootKenny (netman)
 
Renesas DevCon 2010: Starting a QT Application with Minimal Boot
Renesas DevCon 2010: Starting a QT Application with Minimal BootRenesas DevCon 2010: Starting a QT Application with Minimal Boot
Renesas DevCon 2010: Starting a QT Application with Minimal Bootandrewmurraympc
 
政黨票的故事
政黨票的故事政黨票的故事
政黨票的故事Macpaul Lin
 
Porting linux to a new architecture
Porting linux to a new architecturePorting linux to a new architecture
Porting linux to a new architectureKALRAY
 
Porting a new architecture (NDS32) to open wrt project
Porting a new architecture (NDS32) to open wrt projectPorting a new architecture (NDS32) to open wrt project
Porting a new architecture (NDS32) to open wrt projectMacpaul Lin
 
Kernel init
Kernel initKernel init
Kernel initgowell
 
U boot source clean up project how-to
U boot source clean up project how-toU boot source clean up project how-to
U boot source clean up project how-toMacpaul Lin
 
U boot 程式碼打掃計畫
U boot 程式碼打掃計畫U boot 程式碼打掃計畫
U boot 程式碼打掃計畫Macpaul Lin
 
Quickboot on i.MX6
Quickboot on i.MX6Quickboot on i.MX6
Quickboot on i.MX6Gary Bisson
 
How to build a community in a company blue&macpaul coscup2015
How to build a community in a company blue&macpaul coscup2015How to build a community in a company blue&macpaul coscup2015
How to build a community in a company blue&macpaul coscup2015Macpaul Lin
 
Why sending patches back is so important
Why sending patches back is so importantWhy sending patches back is so important
Why sending patches back is so importantMacpaul Lin
 
Module 4 Embedded Linux
Module 4 Embedded LinuxModule 4 Embedded Linux
Module 4 Embedded LinuxTushar B Kute
 
Linux Kernel Booting Process (2) - For NLKB
Linux Kernel Booting Process (2) - For NLKBLinux Kernel Booting Process (2) - For NLKB
Linux Kernel Booting Process (2) - For NLKBshimosawa
 
OpenWRT, A value-add base solution for your product. (2nd, Macpual)
OpenWRT, A value-add base solution for your product. (2nd, Macpual)OpenWRT, A value-add base solution for your product. (2nd, Macpual)
OpenWRT, A value-add base solution for your product. (2nd, Macpual)Macpaul Lin
 
ELC-E 2010: The Right Approach to Minimal Boot Times
ELC-E 2010: The Right Approach to Minimal Boot TimesELC-E 2010: The Right Approach to Minimal Boot Times
ELC-E 2010: The Right Approach to Minimal Boot Timesandrewmurraympc
 
從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗
從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗
從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗Macpaul Lin
 

Andere mochten auch (20)

Mainline U-BOOT for iMX6 (AR6MX)
Mainline U-BOOT for iMX6 (AR6MX)Mainline U-BOOT for iMX6 (AR6MX)
Mainline U-BOOT for iMX6 (AR6MX)
 
Micro-controller course lec 01
Micro-controller course lec 01Micro-controller course lec 01
Micro-controller course lec 01
 
Linux fundamental - Chap 11 boot
Linux fundamental - Chap 11 bootLinux fundamental - Chap 11 boot
Linux fundamental - Chap 11 boot
 
Renesas DevCon 2010: Starting a QT Application with Minimal Boot
Renesas DevCon 2010: Starting a QT Application with Minimal BootRenesas DevCon 2010: Starting a QT Application with Minimal Boot
Renesas DevCon 2010: Starting a QT Application with Minimal Boot
 
政黨票的故事
政黨票的故事政黨票的故事
政黨票的故事
 
Porting linux to a new architecture
Porting linux to a new architecturePorting linux to a new architecture
Porting linux to a new architecture
 
Porting a new architecture (NDS32) to open wrt project
Porting a new architecture (NDS32) to open wrt projectPorting a new architecture (NDS32) to open wrt project
Porting a new architecture (NDS32) to open wrt project
 
Kernel init
Kernel initKernel init
Kernel init
 
U boot source clean up project how-to
U boot source clean up project how-toU boot source clean up project how-to
U boot source clean up project how-to
 
U boot 程式碼打掃計畫
U boot 程式碼打掃計畫U boot 程式碼打掃計畫
U boot 程式碼打掃計畫
 
Quickboot on i.MX6
Quickboot on i.MX6Quickboot on i.MX6
Quickboot on i.MX6
 
How to build a community in a company blue&macpaul coscup2015
How to build a community in a company blue&macpaul coscup2015How to build a community in a company blue&macpaul coscup2015
How to build a community in a company blue&macpaul coscup2015
 
Why sending patches back is so important
Why sending patches back is so importantWhy sending patches back is so important
Why sending patches back is so important
 
Module 4 Embedded Linux
Module 4 Embedded LinuxModule 4 Embedded Linux
Module 4 Embedded Linux
 
Qt5 embedded
Qt5 embeddedQt5 embedded
Qt5 embedded
 
Linux Kernel Booting Process (2) - For NLKB
Linux Kernel Booting Process (2) - For NLKBLinux Kernel Booting Process (2) - For NLKB
Linux Kernel Booting Process (2) - For NLKB
 
OpenWRT, A value-add base solution for your product. (2nd, Macpual)
OpenWRT, A value-add base solution for your product. (2nd, Macpual)OpenWRT, A value-add base solution for your product. (2nd, Macpual)
OpenWRT, A value-add base solution for your product. (2nd, Macpual)
 
Porting Android
Porting AndroidPorting Android
Porting Android
 
ELC-E 2010: The Right Approach to Minimal Boot Times
ELC-E 2010: The Right Approach to Minimal Boot TimesELC-E 2010: The Right Approach to Minimal Boot Times
ELC-E 2010: The Right Approach to Minimal Boot Times
 
從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗
從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗
從u-boot 移植 NDS32 談 嵌入式系統開放原始碼開發的 一些經驗
 

Ähnlich wie Linux Porting

Study on Android Emulator
Study on Android EmulatorStudy on Android Emulator
Study on Android EmulatorSamael Wang
 
Linux Kernel Tour
Linux Kernel TourLinux Kernel Tour
Linux Kernel Toursamrat das
 
LCU14 302- How to port OP-TEE to another platform
LCU14 302- How to port OP-TEE to another platformLCU14 302- How to port OP-TEE to another platform
LCU14 302- How to port OP-TEE to another platformLinaro
 
I/O, You Own: Regaining Control of Your Disk in the Presence of Bootkits
I/O, You Own: Regaining Control of Your Disk in the Presence of BootkitsI/O, You Own: Regaining Control of Your Disk in the Presence of Bootkits
I/O, You Own: Regaining Control of Your Disk in the Presence of BootkitsCrowdStrike
 
Raspberry Pi tutorial
Raspberry Pi tutorialRaspberry Pi tutorial
Raspberry Pi tutorial艾鍗科技
 
U boot porting guide for SoC
U boot porting guide for SoCU boot porting guide for SoC
U boot porting guide for SoCMacpaul Lin
 
#include avrinterrupt.h The global interrupt flag is maintained.pdf
#include avrinterrupt.h The global interrupt flag is maintained.pdf#include avrinterrupt.h The global interrupt flag is maintained.pdf
#include avrinterrupt.h The global interrupt flag is maintained.pdfarasanlethers
 
[Defcon] Hardware backdooring is practical
[Defcon] Hardware backdooring is practical[Defcon] Hardware backdooring is practical
[Defcon] Hardware backdooring is practicalMoabi.com
 
“Linux Kernel CPU Hotplug in the Multicore System”
“Linux Kernel CPU Hotplug in the Multicore System”“Linux Kernel CPU Hotplug in the Multicore System”
“Linux Kernel CPU Hotplug in the Multicore System”GlobalLogic Ukraine
 
Advanced Root Cause Analysis
Advanced Root Cause AnalysisAdvanced Root Cause Analysis
Advanced Root Cause AnalysisEric Sloof
 
Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...
Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...
Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...Vincenzo Iozzo
 
System Booting Process overview
System Booting Process overviewSystem Booting Process overview
System Booting Process overviewRajKumar Rampelli
 
U-Boot presentation 2013
U-Boot presentation  2013U-Boot presentation  2013
U-Boot presentation 2013Wave Digitech
 
Linuxdd[1]
Linuxdd[1]Linuxdd[1]
Linuxdd[1]mcganesh
 
Bootloaders (U-Boot)
Bootloaders (U-Boot) Bootloaders (U-Boot)
Bootloaders (U-Boot) Omkar Rane
 

Ähnlich wie Linux Porting (20)

Study on Android Emulator
Study on Android EmulatorStudy on Android Emulator
Study on Android Emulator
 
Linux Kernel Tour
Linux Kernel TourLinux Kernel Tour
Linux Kernel Tour
 
LCU14 302- How to port OP-TEE to another platform
LCU14 302- How to port OP-TEE to another platformLCU14 302- How to port OP-TEE to another platform
LCU14 302- How to port OP-TEE to another platform
 
I/O, You Own: Regaining Control of Your Disk in the Presence of Bootkits
I/O, You Own: Regaining Control of Your Disk in the Presence of BootkitsI/O, You Own: Regaining Control of Your Disk in the Presence of Bootkits
I/O, You Own: Regaining Control of Your Disk in the Presence of Bootkits
 
Raspberry Pi tutorial
Raspberry Pi tutorialRaspberry Pi tutorial
Raspberry Pi tutorial
 
Logging kernel oops and panic
Logging kernel oops and panicLogging kernel oops and panic
Logging kernel oops and panic
 
U boot porting guide for SoC
U boot porting guide for SoCU boot porting guide for SoC
U boot porting guide for SoC
 
#include avrinterrupt.h The global interrupt flag is maintained.pdf
#include avrinterrupt.h The global interrupt flag is maintained.pdf#include avrinterrupt.h The global interrupt flag is maintained.pdf
#include avrinterrupt.h The global interrupt flag is maintained.pdf
 
[Defcon] Hardware backdooring is practical
[Defcon] Hardware backdooring is practical[Defcon] Hardware backdooring is practical
[Defcon] Hardware backdooring is practical
 
“Linux Kernel CPU Hotplug in the Multicore System”
“Linux Kernel CPU Hotplug in the Multicore System”“Linux Kernel CPU Hotplug in the Multicore System”
“Linux Kernel CPU Hotplug in the Multicore System”
 
Advanced Root Cause Analysis
Advanced Root Cause AnalysisAdvanced Root Cause Analysis
Advanced Root Cause Analysis
 
Analisis_avanzado_vmware
Analisis_avanzado_vmwareAnalisis_avanzado_vmware
Analisis_avanzado_vmware
 
How to build and load linux to embedded system
How to build and load linux to embedded systemHow to build and load linux to embedded system
How to build and load linux to embedded system
 
Basic Linux Internals
Basic Linux InternalsBasic Linux Internals
Basic Linux Internals
 
Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...
Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...
Post Exploitation Bliss: Loading Meterpreter on a Factory iPhone, Black Hat U...
 
System Booting Process overview
System Booting Process overviewSystem Booting Process overview
System Booting Process overview
 
U-Boot presentation 2013
U-Boot presentation  2013U-Boot presentation  2013
U-Boot presentation 2013
 
Driver_linux
Driver_linuxDriver_linux
Driver_linux
 
Linuxdd[1]
Linuxdd[1]Linuxdd[1]
Linuxdd[1]
 
Bootloaders (U-Boot)
Bootloaders (U-Boot) Bootloaders (U-Boot)
Bootloaders (U-Boot)
 

Mehr von Champ Yen

Halide tutorial 2019
Halide tutorial 2019Halide tutorial 2019
Halide tutorial 2019Champ Yen
 
Linux SD/MMC Driver Stack
Linux SD/MMC Driver Stack Linux SD/MMC Driver Stack
Linux SD/MMC Driver Stack Champ Yen
 
Simd programming introduction
Simd programming introductionSimd programming introduction
Simd programming introductionChamp Yen
 
Video Compression Standards - History & Introduction
Video Compression Standards - History & IntroductionVideo Compression Standards - History & Introduction
Video Compression Standards - History & IntroductionChamp Yen
 
OpenCL Kernel Optimization Tips
OpenCL Kernel Optimization TipsOpenCL Kernel Optimization Tips
OpenCL Kernel Optimization TipsChamp Yen
 
OpenGL ES 2.x Programming Introduction
OpenGL ES 2.x Programming IntroductionOpenGL ES 2.x Programming Introduction
OpenGL ES 2.x Programming IntroductionChamp Yen
 
Chrome OS Observation
Chrome OS ObservationChrome OS Observation
Chrome OS ObservationChamp Yen
 
Play With Android
Play With AndroidPlay With Android
Play With AndroidChamp Yen
 

Mehr von Champ Yen (8)

Halide tutorial 2019
Halide tutorial 2019Halide tutorial 2019
Halide tutorial 2019
 
Linux SD/MMC Driver Stack
Linux SD/MMC Driver Stack Linux SD/MMC Driver Stack
Linux SD/MMC Driver Stack
 
Simd programming introduction
Simd programming introductionSimd programming introduction
Simd programming introduction
 
Video Compression Standards - History & Introduction
Video Compression Standards - History & IntroductionVideo Compression Standards - History & Introduction
Video Compression Standards - History & Introduction
 
OpenCL Kernel Optimization Tips
OpenCL Kernel Optimization TipsOpenCL Kernel Optimization Tips
OpenCL Kernel Optimization Tips
 
OpenGL ES 2.x Programming Introduction
OpenGL ES 2.x Programming IntroductionOpenGL ES 2.x Programming Introduction
OpenGL ES 2.x Programming Introduction
 
Chrome OS Observation
Chrome OS ObservationChrome OS Observation
Chrome OS Observation
 
Play With Android
Play With AndroidPlay With Android
Play With Android
 

Kürzlich hochgeladen

Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersThousandEyes
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...shyamraj55
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonetsnaman860154
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking MenDelhi Call girls
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhisoniya singh
 
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsEnterprise Knowledge
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationSafe Software
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountPuma Security, LLC
 
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 3652toLead Limited
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdfhans926745
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking MenDelhi Call girls
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGSujit Pal
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024Scott Keck-Warren
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...HostedbyConfluent
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 

Kürzlich hochgeladen (20)

Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for PartnersEnhancing Worker Digital Experience: A Hands-on Workshop for Partners
Enhancing Worker Digital Experience: A Hands-on Workshop for Partners
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
 
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path Mount
 
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
Tech-Forward - Achieving Business Readiness For Copilot in Microsoft 365
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAG
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 

Linux Porting

  • 1. Linux Porting for new ARM platform Champ Yen http://champyen.blogspot.com champ.yen@gmail.com
  • 2. OutLine GNU Toolchain Linux Kernel Prerequisites and Assumptions Images Boot Sequence Kernel Configuration & Compilation Kernel Porting Device Drivers Boot Options initramfs vs initrd References
  • 3. GNU Toolchains  CodeSourcery gnu toolchain http://www.codesourcery.com/sgpp/lite/arm/download.html  Buildroot http://buildroot.uclibc.org/  Scratchbox http://www.scratchbox.org/  OpenEmbedded http://wiki.openembedded.net/index.php/Main_Page  Ptxdist http://www.pengutronix.de/software/ptxdist/index_en.html
  • 4. GNU Toolchains - buildroot  linux kernel like configuration interface ncurse UI, .config file  uClibc generate linux 2.6 compatible small footprint applications  for most platform remember to enable software float  output: toolchain/uClibc/busybox/rootfs
  • 5. Linux Kernel Prerequisites and Assumptions  DRAM is initialized  Hardware-related initialization tasks are done  MMU/Cache is disabled  specific values should be saved in registers r1: Machine ID, r2: pointer of ATAG list (optional)
  • 6. Images and intermediate files piggy.o image vmlinuz objcopy (binary gzip piggy.gz asm (ELF object) object) misc.o compressed head.o stripped image binary kernel binary kernel bootable kernel image kernel proper (zImage)
  • 7. Boot Sequence start arch/arm/boot/ start compressed/ head.S start_kernel arch/arm/kernel/ head.S bootstrap loader init/main.c (uncompress) ARM-specific kernel code kernel code detail boot sequence is listed in [9]
  • 8. Kernel Porting – Kernel Memory Map 0xFFFF_FFFF CPU vector page/copy_user_page(),clear_user_page() 0xFFFF_0000 DMA memory mapping 0xFF00_0000 free for platform use VMALLOC_END vmalloc()/ioremap() space VMALLOC_START kernel direct-mapped RAM region PAGE_OFFSET kernel module space TASK_SIZE user space mapping 0x0000_1000 CPU vector page/null pointer trap 0x0000_0000
  • 9. Kernel Porting – Directories  mm/ memory-handling related code  boot/ bootstrap loader code  kernel/ ARM architecture dependent code  mach-XXXXXX/ specific machine dependent code  configs/ each machine’s default kernel configurations
  • 10. Kernel Porting – new machine items refer to other machine to create or modify items(ex: foo, fxx)  register the new machine arch/arm/tools/mach-types  Create machine folder arch/arm/mach-fxx arch/arm/mach-fxx/include/mach  Modify or Create Kconfig & Makefile arch/arm/Kconfig (usually add config ARCH_FXX for architecture) arch/arm/Makefile arch/arm/mm/Kconfig arch/arm/mach-fxx/Kconfig (config MACH_FOO for machine) arch/arm/mach-fxx/Makefile arch/arm/mach-fxx/Makefile.boot (set zreladdr-y for image location)
  • 11. Kernel Porting – new machine items register the new machine  Add an entry in arch/arm/tools/mach-types ex: foo MACH_FOO FOO 65535  For official registration, should register here, also. http://www.arm.linux.org.uk/developer/machines/
  • 12. Kernel Porting – new machine items create machine folders  arm/arch/mach-fxx for machine dependent source code  arm/arm/mach-fxx/include/mach for machine dependent headers/assembly debug-macro.S: adduart, senduart, busyuart, waituart dma.h entry-macro.S: macro get_irqnr_and_base hardware.h system.h: arch_idle(), arch_reset() io.h timex.h: CLOCK_TICK_RATE irqs.h: NR_IRQS uncompress.h: putc() memory.h: PHYS_OFFSET vmalloc.h: VMALLOC_END
  • 13. Kernel Porting – new machine items modify or create Kconfig & Makefile  arch/arm/Kconfig config ARCH_FXX bool “FXX family processors“ help This enables support for systems based on the fxx processors. ……… source "arch/arm/mach-fxx/Kconfig"  arch/arm/Makefile machine-$(CONFIG_ARCH_FXX) := fxx  arch/arm/mm/Kconfig (ex: ARM926-based) config CPU_ARM926T bool "Support ARM926T processor" depends on ARCH_INTEGRATOR || ARCH_VERSATILE_PB || … || ARCH_FXX default y if ARCH_VERSATILE_PB || ARCH_VERSATILE_AB || … || ARCH_FXX
  • 14. Kernel Porting – new machine items modify or create Kconfig & Makefile  arch/arm/mach-fxx/Kconfig menu "FXX platform type“ depends on ARCH_FXX config MACH_FOO bool "Support FOO platform" default y help Include support for the FOO platform. endmenu  arch/arm/mach-fxx/Makefile # Common support (must be linked before board specific support) obj-y := architecture depend code # Specific board support obj-$(CONFIG_MACH_FOO) += core.o machine depend code  arch/arm/mach-fxx/Makefile.boot zreladdr-y := 0x01008000
  • 15. Kernel Porting – description structure MACHINE_START(FOO, "FOO processor") /* Maintainer: Champ Yen */ .map_io = foo_map_io, .init_irq = foo_init_irq, .init_machine = foo_init, .timer = &foo_timer, /* for ATAG list is optional */ .boot_params = 0x01000100, MACHINE_END
  • 16. Kernel Porting – Initialization code  I/O Memory Mapping Table  IRQ  Timer struct sys_timer  Initial order: .map_io .initrq .timer .init_machine
  • 17. Kernel Porting – I/O Memory Map static struct map_desc foo_io_desc[] __initdata = { { /* address after mapping */ .virtual = IO_ADDRESS(CPU_DEV_PHY_BASE), /* page index of physical address */ .pfn = __phys_to_pfn(CPU_DEV_PHY_BASE), .length = CPU_DEV_IO_LEN, /* address mapping range */ .type = MT_DEVICE /* I/O type */ }, …… }; …. static void __init foo_map_io(void) { iotable_init(foo_io_desc, ARRAY_SIZE(foo_io_desc)); }
  • 18. Kernel Porting – IRQ  arch/arm/mach-fxx/include/mach/entry-macro.S get_irqnr_and_base: after calling irqnr: irq number, not equal condition should be set.  arch/arm/mach-fxx/include/mach/irqs.h NR_IRQS (number of irq types) should be defined  struct irq_chip, irqaction set_irq_chip(), set_irq_flags(), set_irq_handler(), setup_irq() ……… static struct irq_chip foo_irq_chip = { for(i = o; i < NR_IRQS; i++){ .ack = foo_int_ack, set_irq_handler(i, handle_level_irq); .mask = foo_int_mask, set_irq_chip(i, &foo_irq_chip); .unmask = foo_int_unmask, set_irq_flags(i, IRQF_VALID); }; } ………
  • 19. Kernel Porting - Timer struct sys_timer foo_timer = { .init = foo_timer_init, .offset = foo_gettimeoffset, };
  • 20. Kernel Porting – DMA memory (optional)  Influence to dma_alloc_coherent() usage  In arch/arm/mach-fxx/include/mach/dma.h  MAX_DMA_ADDRESS  In arch/arm/mach-fxx/include/mach/memory.h  CONSISTENT_DMA_SIZE  ISA_DMA_THRESHOLD
  • 21. Boot Options – static string  Boot options -> Default kernel command string ex: mem=8M@0x01000000 initrd=0x01180000,145762
  • 22. Boot Options – ATAG lists  ATAG provides dynamic boot option passing  There are two way to pass pointer of ATAG lists r2 value passed by bootloader, .boot_params in machine descriptor  refer to arch/arm/include/asm/setup.h struct tag_header { __u32 size; ATAG_CORE __u32 tag; }; …… struct tag { struct tag_header hdr; union { struct tag_core core; struct tag_mem32 mem; … } u; ATAG_NONE };
  • 23. Device Drivers  platform_device_register(), platform_driver_register() for some on-chip devices(ex: clock/power control)  UART subsystem in driver/serial for startup message, console ,and shell  Framebuffer subsystem in driver/video
  • 24. initramfs vs initrd initrd initramfs image ext2 image + gzip cpio + gzip implementation block device tmpfs first execution /linuxrc /init mount rootfs pivot_root switch_root initrd requires ext2 and block devices support. It adds 150KB+ to kernel size.
  • 25. initramfs  create an initramfs image by command: find . | cpio -o -H newc | gzip > ../initramfs.cpio.gz  take care of the distance between image and kernel, otherwise image will be overwritten by kernel.  /init ex: #!/bin/busybox sh #/bin/busybox --install mount -t proc proc /proc exec /bin/busybox sh
  • 26. Debug  decompression: putc() definiition in include/mach/uncompress.h  kernel debugging features in kernel hacking of kernel options (and CONFIG_DEBUG_LL option for low level debugging)  early debug: printascii/printhex(2,4,8) make use of uart macros in include/mach/debug-macro.S  printk()  CONNFIG_KGDB
  • 27. References  Embedded Linux Primer, Christopher Hallinan, Prentice Hall  Building Embedded Linux Systems 2/e, Karim Yaghmour, Oreilly  linux-2.6.2x-xx/Documentation/arm  http://heaven.branda.to/~thinker/GinGin_CGI.py/get_afile/166/porting_to_arm.pdf  http://www.glomationinc.com/PortingLinuxKernel.pdf  http://www.ens-lyon.fr/LIP/Pub/Rapports/RR/RR2006/RR2006-08.pdf  http://glt08.linuxtage.at/slides/glt08-kvas_linuxonarm.pdf  http://www.linux-arm.org/LinuxKernel/LinuxNewPlatformPort  http://gicl.cs.drexel.edu/people/sevy/linux/ARM_Linux_boot_sequence.html  http://www.simtec.co.uk/products/SWLINUX/files/booting_article.html  http://www.ibm.com/developerworks/linux/library/l-initrd.html  http://blog.linux.org.tw/~jserv/archives/001954.html
  • 28. Q&A