-
Notifications
You must be signed in to change notification settings - Fork 170
Home
Welcome to the Adaptive Runtime AUTOSAR Linux Simulator wiki! The project wiki consists of pages related to the project goal, the project scope and its alignment with the AUTOSAR Adaptive standard, the project timeline, and technical design documents. The aim of this project is to provide students/researchers in the automotive engineering a big picture of Adaptive Runtime AUTOSAR and an overview about how its interfaces should be implemented. This repository does not rely on any hardware requirement (e.g., an ECU emulator), but it is able to interact with some hardware interfaces (i.e., CAN bus, LIN bus, and Ethernet).
The project does not cover fully the AUTOSAR Adaptive standard. Following table indicates the different domains of the standard, and the project compatibility with each domain:
A sample of LIN bus communication is part of the scope.
Partially implemented based on R20-11:
-
E2E communication protection (
ara::com::e2e
) implementation is not planned yet. -
Raw data streaming (
ara::com::raw
) is out of scope. -
Communication Group (
ara::com::cg
) is not fully implemented yet. -
Network binding is limited to SOME/IP (Signal-Based and DDS network bindings are out of scope):
-
SOME/IP Service Discovery (SD) only supports IPv4 endpoints.
-
Network link status change is not simulated in the SD finite state machine (FSM).
-
SD Client Requested_but_not_read state is removed from the FSM.
-
The
ara::com::someip::sd
andara::com::someip::pubsub
namespaces and their sub-namespaces are not part of the official standard.
-
-
Secure Onboard Communication (
ara::com::secoc
) is out of scope.
Fully implementation is not part of the plan, and the scope is limited to an integration with Volvo Extended Vehicle and Connected Vehicle APIs.
Out of scope
Interfaces are partially defined based on R20-11 and the plan is to at last enable the functional cluster to communicate with OBD-II and DoIP.
The scope of the State Management is limited to control only the Power Mode via interaction with the Diagnostics functional cluster.The State Management development is in progress based on R21-11.
Out of scope
It is part of the plan, but the scope is not determined yet.
The Log & Trace is mostly implemented based on R20-11:
-
Log sinks are limited to console and file sinks (network sink is out of scope).
-
The
ara::log::sink
namespace is not part of the official standard. -
Current implementation does not support hexadecimal format, binary format, and
ClientState
logging.
Out of scope
It is barely implemented partly based on R21-11 and partly based on R20-11 (which finally will migrate to R21-11 as well). The implementation scope is as follows:
Data type | Implementation revision | Compatibility | Replaced alternative |
---|---|---|---|
ErrorDomain |
R21-11 | Lacking SupportData
|
- |
ErrorCode |
R21-11 | Incompatible constructors | - |
Exception |
- | - | std::exception |
Result |
R20-11 | Incompatible noexcept specifiers, dedicated specialized global (in)equality operator, and lacking non-member swap method | - |
Future |
R21-11 (planned) | Unknown | std::future |
Promise |
R21-11 (planned) | Unknown | std::promise |
Array |
- | - | std::array |
Vector |
- | - | std::vector |
Map |
- | - | std::map |
Optional |
C++17 | Some constructor overloads are missing | - |
Variant |
- | - | Out of scope |
StringView |
- | - | std::string |
String |
- | - | std::string |
Span |
- | - | Out of scope |
SteadyClock |
- | - | std::chrono::steady_clock |
InstanceSpecifier |
R21-11 | Replacing ara::core::StringView with std::string | - |
ScaleLinearAndTexttable |
- | - | Out of scope |
Byte |
- | - | uint8_t |
The development is in progress based on R21-11:
-
Function Group execution state control is out of scope.
-
Deterministic Client class
noexcept
specifiers are not aligned with the standard.
Out of scope
Out of scope
Out of scope
Currently, there is a wrapper interface around BSD sockets to enable functional clusters (e.g., Communication Management) for interacting via TCP/IP protocol.
Following is the project timeline and its specified milestones within 4 years:
Milestone | Start date | End date | Status |
---|---|---|---|
Studying R19-11 | January 2020 | December 2020 | Done |
Updating to R20-11 | January 2021 | May 2021 | Done |
Launching the repository | May 2021 | June 2021 | Done |
Doxygenizing | September 2021 | September 2021 | Done |
Integrating Async-BSD-Socket-Lib | October 2021 | October 2021 | Done |
Implementing SOME/IP | October 2021 | December 2021 | Done |
Finalizing EM and SM | December 2021 | January 2022 | In progress |
Developing CAN OBD-II Linux Driver | January 2022 | February 2022 | To do |
Implementing DoIP of DM | February 2022 | March 2022 | To do |
Developing LIN bus bare-metal hardware interface | March 2022 | May 2022 | To do |
Break | May 2022 | December 2022 | - |
Implementing LIN bus Adaptive Application | January 2023 | March 2023 | To do |
Implementing RESTful | April 2023 | May 2023 | To do |
Finalizing ARA Core (ara::core::Future/Promise implementation) | June 2023 | June 2023 | To do |
Implementing PHM | July 2023 | August 2023 | To do |
Implementing E2E communication protection | September 2023 | September 2023 | To do |
Researching about dedicated memory allocator | October 2023 | December 2023 | To do |
Aligning with MISRA certification | December 2023 | January 2024 | To do |