Skip to content
Snippets Groups Projects
This project is mirrored from https://github.com/seL4/seL4.git. Pull mirroring failed .
Repository mirroring has been paused due to too many failed attempts. It can be resumed by a project maintainer or owner.
Last successful update .
  1. Jul 05, 2019
  2. Jul 03, 2019
    • Japheth Lim's avatar
      exynos4, exynos5, sabrelite: clamp memory to fit in kernel window · 0a5499bd
      Japheth Lim authored
      This is a hack that allows user-space tools like the capDL static
      allocator to work. Otherwise, the allocator (currently unaware of the
      kernel window) would think that there is a 28-bit untyped at pptr
      0xf0000000, and would generate untyped derivations that are not
      available at runtime.
      
      Note that we clamp to 0xff000000 on exynos4 and exynos5, *not*
      0xfff00000 (PPTR_TOP), to avoid the ASID PD hole at
      0xff000000..0xff200000. The affected platforms are ARM VM platforms;
      VM images are often larger than 13MiB and would overlap the ASID hole
      if loaded from PPTR_TOP. init_freemem fails if this overlap exists.
      0a5499bd
    • Anna Lyons's avatar
      tools: store KernelDTBSize as internal cache var · daa2f231
      Anna Lyons authored
      This is so KernelDTBSize can be consumed by other tools.
      daa2f231
    • Kent McLeod's avatar
      CMake: Process platform files in -C config · d5ded0c4
      Kent McLeod authored
      Allow projects that use the kernel as a subproject to configure the
      kernel in -C scripts.
      
      CMake supports providing a script via -C upon first initialisation of a
      build directory. This script is expected to populate the configuration
      cache for the rest of the build to depend on. This is how standalone
      kernel builds are currently configured. However in buildsystems that add
      the kernel as a subproject, it was up to the application to modify
      configuration properties before or after the kernel was imported. This
      lead to circular dependencies where properties were changed by a module
      later in the build, but this then invalidated properties that were set
      based on the first property's original value. This lead to running CMake
      multiple times in order for settings to reach a stable state.
      
      We now assume that most shared system configuration occurs in initial -C
      settings evaluation. seL4Config.cmake is a configuration module that the
      kernel exports that allows a configuration script to set kernel platform
      and architecture settings in a way that doesn't introduce circular
      dependencies.
      
      seL4Config can be imported into other configuration files. This should
      make it easier for a full system configuration script to query and
      configure kernel configuration values without introducing circular
      dependencies on configuration properties.
      d5ded0c4
  3. Jul 02, 2019
  4. Jul 01, 2019
    • Kent McLeod's avatar
      Add initial i.MX8M Quad evk 64-bit Support · 051d32be
      Kent McLeod authored
      This adds support for the 64-bit i.MX8M Quad evaluation kit.
      Currently only AArch64 EL1 is supported.
      051d32be
    • Kent McLeod's avatar
      arm: Rename gic_pl390 to gic_v2 · 0d60f6f2
      Kent McLeod authored
      This is to reflect that this driver provides support for features that
      are newer than gic_pl390 such as virtualisation.
      0d60f6f2
    • Kent McLeod's avatar
      trivial: Update CHANGES for GICv3 · 60e64bd5
      Kent McLeod authored
      60e64bd5
    • Kent McLeod's avatar
      gic: Move common GIC definitions to shared header · 466455f3
      Kent McLeod authored
      Share definitions between gic_pl390.h and gic_v3.h.
      466455f3
    • Kent McLeod's avatar
      gic_v3: Check rwp register value before time · b6184ef1
      Kent McLeod authored
      Checking the value of the register write pending bit before reading from
      the generic timer is an optimisation
      b6184ef1
    • Kent McLeod's avatar
      gic_v3: Add setIRQTrigger · 759a8c76
      Kent McLeod authored
      This enables invocations to change the trigger mode of an IRQ.
      759a8c76
    • Kent McLeod's avatar
      gic_v3: Change EOI mode to drop and deactivation · 53f08062
      Kent McLeod authored
      TODO: Decide what EOI mode we want.
      53f08062
    • Kent McLeod's avatar
      gic_v3: Rename driver from gic_500 · ca01c8d9
      Kent McLeod authored
      This driver should be compatible with GIC v3 implementations
      ca01c8d9
    • Kent McLeod's avatar
      gic_500: Use GIC v3 register definitions · 969c8b93
      Kent McLeod authored
      This is in preparation for providing this driver as a generic GIC v3
      driver.
      969c8b93
    • Kent McLeod's avatar
      gic_500: Move redist init code to own function · c33d5e5a
      Kent McLeod authored
      Separate system register initialisation from redistributor register
      initialisation
      c33d5e5a
    • Kent McLeod's avatar
      gic_500: Make redistributor init code smp aware · d03f8c19
      Kent McLeod authored
      - Use array for storing per-core mapping of the redistributor register
      mappings.
      - Locate the base address of each of these mappings based on iterating
      through the full device mappings looking for matchin MPIDR values.
      - When accessing redistributor registers, index into the array based on
      current logical core id.
      - On single core configurations these arrays only have one element.
      d03f8c19
    • Kent McLeod's avatar
      gic_500: Add mpidr_map and mpidr_to_gic_affinity · 11a83dea
      Kent McLeod authored
      mpidr_map is used to store a lookup from seL4 logical core to mpidr
      value for that core.
      mpidr_to_gic_affinity correctly transforms the mpidr value stored in
      mpidr_map to an appropriate GICD_IROUTER register value.
      11a83dea
    • Jesse Millwood's avatar
      Support for ARM GIC 500 · e4926ccc
      Jesse Millwood authored
      Some ARMv8 cores do not have a GIC that has backwards
      compatibility. This adds ARM GIC 500 (GICv3 and GICv4) support to
      seL4. It should also be noted that there are much more distributor and
      redistributor registers than in previous version. The platform
      implementor that needs a GIC500 should take care to set up the kernel
      devices properly.
      
      Change-Id: Ia7c546f7874a758ecd1ee8a29dd749eb3a2444f3
      e4926ccc
    • Yanyan Shen's avatar
      aarch64: Change the kernel device window to 2 MiB. · eab4529f
      Yanyan Shen authored
      This is required for Arm devices that have more registers and require
      larger memory mappings.
      eab4529f
    • Curtis Millar's avatar
      Update CHANGES to reflect RFC-3 Changes. · a06690fb
      Curtis Millar authored
      a06690fb
    • Curtis Millar's avatar
      Add syscall for setting the current TLS register. · 15091664
      Curtis Millar authored
      Some platforms and configurations do not allow user code to change the
      value of the register used for TLS. On these architectures a syscall can
      be used to allow the kernel to update the register on their behalf.
      
      This does not immediately update the value in the user context on many
      configurations as the values are only stored in the user context on a
      context switch.
      15091664
    • Curtis Millar's avatar
      RFC-3: Update user context for ARM with thread IDs · 5646f774
      Curtis Millar authored
      Switched appropriate naming conventions.
      Was using the aarch64, have switched to aarch64 names.
      
      TIPDRURW -> tpidr_el0
      TPIDRURO -> tpidrro_el0
      TPIDRPRW -> tpidr_el1
      
      Switch TLS register on aarch32 from TPIDURO (tpidrro_el0) to tpidr_ro so
      that it can be written to from user-land.
      
      Thread ID registers tpidr_el0 have been added to the user context for
      aarch32 and aarch64.
      
      Only the thread ID that is writeable from EL0 is saved in the TCB and
      saved/restored on context switch.
      
      Thread IDs that are only changed within a VM (the read-only thread ID
      for exception level 0 and the thread ID for exception level 1) are
      stored in the VCPU and saved and stored as part of VM enable/disable.
      
      Thread IDs that are only changed with VMs have been separated out into
      hypervisor code.
      5646f774
    • Curtis Millar's avatar
      Replace IPC_BUF_GLOBALS_FRAME with KERNEL_GLOBALS_FRAME · fd83c0a3
      Curtis Millar authored
      The globals frame no longer serves its original purpose of informing a
      thread of its IPC buffer address, and instead as a virtual
      implementation of thread ID registers.
      fd83c0a3
    • Curtis Millar's avatar
      RFC-3: Update context for x86 to use FS and GS. · 3207abee
      Curtis Millar authored
      TLS_BASE virtual register is replaced with FS_BASE and GS_BASE virtual
      registers.
      
      The FS_BASE and GS_BASE virtual registers are moved to the end of the
      context so they need not be considered in the kernel exit and entry
      implementation.
      
      Removed tracking of ES, DS, FS, and GS segment selectors on kernel entry
      and exit.
      
      ES and DS are clobbered on kernel entry with the RPL 3 selector for a
      DPL 3 linear data segment.
      
      FS is clobbered on exit with the RPL 3 selector for the DPL 3 segment
      with FS_BASE as the base. This is done on exit to reload the value from
      the GDT.
      
      GS is clobbered on exit with the RPL 3 selector for the DPL 3 segment
      with GS_BASE as the base. This is done on exit to reload the value from
      the GDT.
      
      Kernel entry and exit code is refactored, simplified, and improved in
      light of the above changes.
      
      x64: update verified config to use fsgsbase instr
      
      The verification platform for x64 relies on the fsgsbase instruction.
      3207abee
    • Curtis Millar's avatar
      09d5e245
    • Curtis Millar's avatar
      Remove platform IPC buffer register. · b6417f21
      Curtis Millar authored
      This removes the assumption that each platform sotres the IPC buffer
      address in a platform-specific register. The IPC buffer address is
      instead stored in a thread-local variable in libsel4 which must be
      initialised by the runtime.
      b6417f21
  5. Jun 28, 2019
    • Kent McLeod's avatar
      CMake: Invert plat config.cmake processing order · 4ede700f
      Kent McLeod authored
      Instead of processing each platform CMake file during the arch's
      config.cmake file, we process all of the platform CMake files first.
      This is primarily motivated by wanting to move platform configuration
      into a config file that is processed via a -C argument to the initial
      build initialisation command.
      
      Now a platform config is responsible for setting the kernel architecture
      and it's own platform/arch specific config settings. Where previously a
      platform was chosen in an arch specific way via either setting
      KernelARMPlatform or KernelX86Sel4Arch or KernelRiscVPlatform, a
      platform can now be set by KernelPlatform. In cases where a platform may
      further parameterise its configuration it is free to choose its own
      config options to query. Platforms that support multiple seL4
      architectures should use KernelSel4Arch to query this.  Platforms that
      provide sub platforms such as exynos5 and subplatforms exynos5250,
      exynos5410 and exynos5422 can be selected by specifying
      KernelPlatform=exynos5, KernelARMPlatform=exynos5410 for example.
      4ede700f
    • Jimmy Brush's avatar
      manual: Correct CNode slot size in bytes · affebe29
      Jimmy Brush authored
      It is 16 bytes on 32-bit systems and 32 bytes on 64-bit systems
      affebe29
  6. Jun 27, 2019
  7. Jun 26, 2019
  8. Jun 24, 2019
Loading