Commit Graph

238 Commits

Author SHA1 Message Date
Sam Leffler
69eefbd5c9 Change ProcessManager interfaces to return ProcessManagerError.
Propagate the ProcessManagerError enum through the
PackageManagementInterface and ProcessControlInterface so the client
has more information about why a request failed.

Change-Id: Ic2d8fcf1401edd6faff85fe821443f720d0b00c4
GitOrigin-RevId: 91d668fc56a352776803392d89aacc034cee1f1e
2022-10-06 18:01:42 +00:00
Sam Leffler
cb99661cd0 kata-logger: remove <level> from logged message
Now that logger level is passed with the message it can be added on the
server side if desired. For now just remove it entirely so we have more
space for the actual message.

Change-Id: I7b8dbdb0460cf2bf7b009ddc5d9d70a438f9d803
GitOrigin-RevId: 701ca7a5d32f1ad5c5f583db78b6c5e7625857f4
2022-10-06 18:01:33 +00:00
Sam Leffler
8ace3eb6f2 kata-logger: pass level through LoggerInterface and filter in DebugConsole
Components can reduce the number of rpc's if they set_max_level but by
default pass everything and let the DebugConsole decide what is logged.
With this the shell loglevel command now controls logging from all
components.

Change-Id: I72b77bbf02882ffdba0aaf0b9b88126bfd2e62a1
GitOrigin-RevId: d451e72cf67e41d6ee25ea2995098b5009cf8852
2022-10-06 18:01:22 +00:00
Matt Harvey
4043c8b5b7 Mutex guards kata-uart-client read and write
Change-Id: I5757dcf68f64359b743f458f336a813aeb43c069
GitOrigin-RevId: 1c6c85f95c6509cc915df1b82076942cd540c441
2022-10-06 18:01:13 +00:00
Matt Harvey
7c3cc70ab1 Splits UART tx/rx into separate CAmkES procedures
This ends the behavior where log messages would block on the prompt.

This change does not fix the potential race on dataports if
kata-uart-client read or write has multiple concurrent callers. A later
change will protect those using CAmkES mutexes, although the
alternative of having DebugConsole *own* the UART should also be
considered.

Change-Id: I8d5d8336cd58b9f22cca81ae6aca13b4ed57e7e4
GitOrigin-RevId: e781fd8454d22e0f829d788fe602e431551e259a
2022-10-06 18:01:04 +00:00
Sam Leffler
20c83f6777 Merge "kata-proc-common: improve BundleIdArray marshalling"
GitOrigin-RevId: ec8fb48df635c89eb5ea8b71ecb7bdcfdf111236
2022-10-06 18:00:52 +00:00
Adam Jesionowski
0a952a59f4 kata-ml-coordinator: Fix bit bug
pc_start is a full 16 bits, freeze is 1 bit. Mixed up the bit ands. Need
auto-generation :)

Change-Id: Ib4f701b43e131bfcb448c68b06d2518cf80e8098
GitOrigin-RevId: a7c3c64eb15ffce8e76b28b105832a253a6d580b
2022-10-06 18:00:33 +00:00
Adam Jesionowski
b9cc80a929 kata: MLCoordinator and VectorCoreDriver
Add a VectorCoreDriver component that handles setting vector core CSRs.

Rewrite MLCoordinator to conform to other Kata components. The old code
wasn't useful.

Add `test_mlexecute` command for running ML. Add plumbing from shell to
coordinator.

Change-Id: I3d563f1a343361c95d3ad5b78231fbe9df32b851
GitOrigin-RevId: f3c38839f708743de596339d1b8173315283b772
2022-10-06 18:00:17 +00:00
Sam Leffler
b9e209b008 Overhaul ProcessManager support.
- Split support into three levels:
  o kata_proc_manager::process_manager is a single-threaded implementation
    of ProcessManagerInterface and PackageManagerInterface that uses an
    abstract manager interface to carry out low-level work (used mainly
    to inject fakes for unit testing).
  o kata_proc_manager is a thread-safe wrapper around process_manager that
    has the manager interfaces bound to KataOS; this is the level at which
    we integrate with external components.
  o kata_proc_component is the top-level glue code for the ProcessManager
    camkes component; it has a pre_init function to setup rust support
    (logger, allocator, etc), a run function for the component's control
    block, and wrapper functions for the camkes ProcessControl and
    PackageManagement interfaces.
- Add install, uninstall, start, stop, and bundles shell commands for
  exercising ProcessControlInterface & PackageManagementInterface.

Specifics:
- Bundle id's are now treated internally as SmallString's with &str
  used for passing bundle id's through api's. The BundleId type is
  temporarily used for get_running_bundles() to return information (but
  see below about RawBundleIdData).
- ArrayVec's are replaced with a hashbrown::HashMap
- Bundle objects are Box'd instead of holding refs (now that we have an
  allocator); this eliminates lifetime constraints.
- The manager interface is Box'd to eliminate lifetime constraints.
- Purge ProcessManager::empty(), it's infeasible with the hashmap and
  is not needed with kata_proc_manager support for static decls.
- Add RawBundleIdData support for serialize+deserialize of BundleIdArray;
  no more leaking internal data types to client code.
- Remove bounds check on #bundles recorded; set a nominal capacity
  and fallback to dynamic allocation of the hashmap.
- Manually update ProcessManagerBindings.h (using cbindgen).

Change-Id: I08deaecc997ea96cb794808036540bedd58b3fa4
GitOrigin-RevId: 6e0826940b43b1295d39769b57812a9494b5a4cb
2022-10-06 17:59:52 +00:00
Sam Leffler
1595b3ad6c kata-shell: add loglevel command
Syntax: loglevel [off, info, debug, warn, error, trace]

Change-Id: I6b480626783cd4bf069a7741d7f4670e96c967b6
GitOrigin-RevId: 527aefa1f2b00d17f7f703d43923463b660caa7e
2022-10-06 17:59:29 +00:00
Sam Leffler
0e740d7282 kata-allocator: remove unneeded RefCell
Mutex<Heap>::lock() gives inner mutability so ditch the RefCell that came
from the original Cortex-M code.

Change-Id: Ib0a29069fd63fd87bd94d68439bfeb433c26db8b
GitOrigin-RevId: bbb505f98c8f1614a81090f58f9445a956697690
2022-10-06 17:59:18 +00:00
Sam Leffler
64da97a4a6 Merge "Add kata-panic support."
GitOrigin-RevId: 86b4cf1b25c2796fff0b2f90da6ef76d773c80a9
2022-10-06 17:59:05 +00:00
Sam Leffler
c5e8722a24 Merge "Add LoggerInterface for logging msgs on the console."
GitOrigin-RevId: 256da9ba28b31f1ac3a87cce0098a52ac918de13
2022-10-06 17:58:54 +00:00
Matt Harvey
3afdc04219 Changes UartDriver implementation to use OpenTitan
The preboot code still sends kernel logging to the 16550. A later change
will also port this to OpenTitan or find another alternative.

Change-Id: Ifbf296e2ba9c6b354dd94d4a0640a2105e177fc9
GitOrigin-RevId: 4226974521b31f8ff8cfa21d8d1fcb19290c8265
2022-10-06 17:58:40 +00:00
Sam Leffler
5cea7522fd Fixup kata RELEASE build handling.
- the RELEASE setting is a boolean, correct cmake check
- explicitly force log-level=0 & debug=true in cargo profile.dev entries

NB: to switch between RELEASE + non-RELEASE builds do "m clean",
  change easy-settings.cmake, then "m kata"
Change-Id: If56cd855a9f30313e264a808c0c12df0532194a0
GitOrigin-RevId: b15be5feba41a19a71ff86f00fee0b7bd0942049
2022-10-06 17:58:31 +00:00
Sam Leffler
3d7923e0a3 UartDriver: yield during tx/rx polling
Sprinkle seL4_Yield's in the tx/rx polling loops so other work in the
DebugConsole component happens. This is a band-aid for the driver not
using interrupts.

Change-Id: I600fdc2b01d60b18bb70e80adbfde9b1c348a194
GitOrigin-RevId: f2e90519f53b78a3ee2b42ca4613b1ea34cd4133
2022-10-06 17:58:20 +00:00
Sam Leffler
94358ffec7 Switch to purpose-built global allocator.
Replace LockedHeap with a purpose-built equivalent. This works around
issues where rust_oom was undefined for certain build configs and
facilitates future sel4 integration (e.g. to use dynamically allocated
memory instead of bss).

Change-Id: I54f779ef794104ad1ae95590812d1cd49b4a3734
GitOrigin-RevId: 83474c02e6b6957946fbca4a9aa090bf3c4dbfdc
2022-10-06 17:58:08 +00:00
Sam Leffler
8d7e4bf44a Add a simple rust global allocator to each component.
- add a linked_list_allocator::LockedHeap instance to each component that
  might want to allocate memory and init the allocator with a fixed-size
  memory block in the component post_init hook
- add an alloc_test shell command that exercises the allocator

This does not dynamically add memory or support sharing memory between
components; this is an intermediate step to simplify bringing in crates
that want to allocate memory (e.g. hashbrown)..

Change-Id: Idaf11fb5d4999218c75bf932133df24de35e3053
GitOrigin-RevId: 7c9b14bf9463239ce030c374b58a140f0835759e
2022-10-06 17:57:56 +00:00
Matt Harvey
e4973577ec Adds kata Makefile step call OpenTitan regtool
To write s3L4 for OpenTitan matcha, we want to depend on generated C
header files for definitions of MMIO sizes, offsets, masks, bit
meanings, etc.

To make these header files available to the seL4 build, this change adds
a make prerequisite for the kata build to run regtool.py with output
going to out/kata/opentitan-gen.

In CAmkES CMake files, the INCLUDE attribute can be used to add to the
include path, and this change also does that for the UartDriver
component. (The implementation will be left for a later change, since an
initial straighforwrd attempt saw writes still going to the 16550.)

Change-Id: If7e7e206ddcf625b8f5a45dc6486693cab7c51e2
GitOrigin-RevId: 018b9ddf9cde2389fb9f39553095d955705cb7a0
2022-10-06 17:57:47 +00:00
June Tate-Gans
a01ee363ea rust: Remove a rogue duplicate rust.cmake file
This only serves to confuse the cmake build tools into using the wrong
definitions, instead of the ones used in apps/system/rust.cmake.

Change-Id: Iaed204a8f8a9ae5fc2233dc4f9147ba6cf6a9a25
GitOrigin-RevId: 290682ee7b8eb7ad00a52f72c0f6e3be08e88673
2022-10-06 17:57:38 +00:00
Austin Appleby
622727086d Disable BBL in easy-settings
Change-Id: I1c2524968246bae00009092a5cedcedd962e66c9
GitOrigin-RevId: d4f6df0a8405a61251a93781d0fc4e67934f8920
2022-10-06 17:57:24 +00:00
Austin Appleby
ff08436a47 Add .gitignore to kata/projects/processmanager
Change-Id: I472245c8dc984f6db18fe24e662fcd08af4cc11d
GitOrigin-RevId: 53774f360e4b450f9544f2561a2047ba64345f01
2022-10-06 17:57:06 +00:00
June Tate-Gans
af63371fd9 Merge "rust-toolchain: Use riscv32imac and better handle build tweaks"
GitOrigin-RevId: 50e4058c935cf522124ce2983d36ca4013ce1940
2022-10-06 17:56:54 +00:00
June Tate-Gans
83d2875eb2 rust: Add in link-time optimization by default
This turns on "fat" LTO for builds even in dev mode so that we can keep our
binaries size down. It's not a total solution, but eliminates the "kitchen sink"
effect that building Rust static libs has, allowing us to keep our dependencies
down a bit.

Change-Id: I5fb071d7cdb7b9964b2af25d8137944593bd065c
GitOrigin-RevId: fe7f105307e042c211be5d031870d6161d71e27c
2022-10-06 17:56:41 +00:00
Sam Leffler
e35c69ae4c Add initial ProcessMaanger interfaces.
- new ProcessManager component (aka kata-process-manager)

NB: interfaces/ProcessManagerBindings.h is manually generated by cbindgen
for the moment; e.g.
  cargo install cbindgen;
  cd components/ProcessManager; cbindgen -c cbindgen.toml \
      -o ../../interfaces/ProcessManagerBindings.h kata-proc-common

Change-Id: I153c6b193c6ba8e376b87a2563dc8543753f0b42
GitOrigin-RevId: 18c354f14cbec6ce01c020136fe9aefd88248ee9
2022-10-06 17:56:26 +00:00
Sam Leffler
c61d7890a7 Add SeL4Debug component to expose sel4 debug syscalls.
- add a SeL4Debug component that wraps seL4DebugPutString and seL4DumpScheduler
  system calls that are marked static inline (so not callable from rust)
- connect seL4Debug to the DebugConsole and add a "ps" command to the shell
  that uses sel4DumpScheduler to print the tcb's on the console; e.g.

KATA_PROMPT> ps
Dumping all tcbs!
Name                                            State           IP                       Prio    Core
--------------------------------------------------------------------------------------
                     sel4debug:sel4debug                running 0x1017e                  254    0
                 sel4debug:fault_handler        blocked on recv 0x1046e                  255    0
                       sel4debug:control        blocked on recv 0x1046e                  254    0
                                drv:uart        blocked on recv 0x11dc4                  254    0
                       drv:fault_handler        blocked on recv 0x105d4                  255    0
                             drv:control        blocked on recv 0x105d4                  254    0
             debug_console:fault_handler        blocked on recv 0x10840                  255    0
                   debug_console:control        blocked on reply        0x12808                  254    0
                             idle_thread                   idle 0                          0    0
                              rootserver               inactive 0x10558                  255    0

Change-Id: I48496ec0002e3307aaeb5c779319d4beb87ae56b
GitOrigin-RevId: 8665f609bdb7efd3b814b4f40abf08c5dd1e863d
2022-10-06 17:56:12 +00:00
Austin Appleby
d602aa29d5 Merge "Remove the Kanji prompt character and add a printf when the repl starts up so we can see it in the Renode log."
GitOrigin-RevId: cd401621c05352bbdd10a70fbf788c58bc2efa10
2022-10-06 17:56:01 +00:00
Sam Leffler
a859632f85 Fix RustAddLibrary for multiple components.
Change-Id: I74a5a5a72817559766d65a485493474de5e8487c
GitOrigin-RevId: 4116bed377cf8d851d8a81e250caf236f330f1f4
2022-10-06 17:55:51 +00:00
Sam Leffler
16d547d52d kata-uart-client: use correct type for dataports
Change-Id: I07224179314dbecc35f343e8e87b77886aa2108b
GitOrigin-RevId: 89e342f858475c1ab5695621ab1f46e70e6d45ca
2022-10-06 17:55:42 +00:00
Adam Jesionowski
90e9cb95f9 Start ML Coordinator.
ML Coordinator needs to be able to load and unload models, which means verifying
and creating any necessary transfer buffers and other data structures.
First draft just keeps track of model references.

ML Coordinator needs to be able to execute models. Actual execution is
abstracted away from ExecutiveInterface.

Deletes fake_executive and moves to this file in the test section, as
this is currently the only user.

Change-Id: Ib2de5bc5761ccffe244e0bc0a02c6d2805cc00c6
GitOrigin-RevId: dc4de0085b36094ec6ac10c3a7f4fe0c8dff1627
2022-10-06 17:55:30 +00:00
Austin Appleby
1c107b73e5 Merge "Move sel4 uart to match hw team's memory map (uart3)"
GitOrigin-RevId: e917b6a81c73f04b0520a9d7e9029415387c2c5e
2022-10-06 17:55:22 +00:00
Matt Harvey
16fda25099 Switches platform from spike to sparrow
Change-Id: Ie086289080bb94e6cf3bc0e28a101d2e0db2000c
GitOrigin-RevId: 6de1d47766d977281f5cab7671637c31b2220d52
2022-10-06 17:55:14 +00:00
Matt Harvey
e45abd8d3e Merge "Adds kata settings for seL4 kernel internal logger and bbl enablement"
GitOrigin-RevId: 8d5a288654f428138bdd6ba0074aa74327773c86
2022-10-06 17:55:01 +00:00
Adam Jesionowski
7e8c603b43 Start ML Coordinator.
Create some common data types and a fake executive. The fake executive
can either return an error (emulating execution failing) or a slice of
memory (emulating a correct result).

Change-Id: Id57f3ea3ee8db64b8921bf7446bcdf143d0daf49
GitOrigin-RevId: e266431d90864c0cd15567221acfa28a02c85a63
2022-10-06 17:54:51 +00:00
June Tate-Gans
31401be481 style: Put cmake keywords on the same line as their parameters
Change-Id: I8e6ecfa1e99e4f880f88928f561fc060d53dca0d
GitOrigin-RevId: 229aa4fddf2dc4ba496e8870d1b4f5f6ee919f35
2022-10-06 17:54:42 +00:00
June Tate-Gans
fa1c3cecd6 shell: Update prompt with Kanji character for kata
Change-Id: If76d7a83798f49e463cb7af24ee5e14320b0aed0
GitOrigin-RevId: dc142976c68a9d7af3027de8ff2d6cb566812c83
2022-10-06 17:54:31 +00:00
Matt Harvey
fd2bebb81f Replaces processmanager with a one-app CAmkES assembly for the entire Kata OS
This also adds a skeleton for the DebugConsole CLI taking IO from a UART
via some Rust wrapper functions, also defined in this change
(kata-uart-client).

Change-Id: I56856c14992010483da58c45f6550c0a4c9987b0
GitOrigin-RevId: e1b2d65ed3a7f627a9f7377caa407151fc943864
2022-10-06 17:54:23 +00:00
June Tate-Gans
5007f2c48c processmanager: Initial project skeleton
This should give us a root task that simply says "Hello, World!" on start. This
is just a stand-in for what will come next.

Change-Id: I402c311d1c89a047dfaa12ab64d880bb1dea00b7
GitOrigin-RevId: aeeb8bc1f8175888d272ff7283df244fb94cc888
2022-10-06 17:54:12 +00:00