Skip to main content

The parser for EB XDM file

Project description

1. py-eb-model

  1. The python parser engine for EB Tresos Xdm file.
  2. To support EB Tresos data model with python.

2. How to create the distribution and upload to pypi

  1. Run python setup.py bdist_wheel to generate distribution
  2. Run twine check dist/* to check the validation of distribution
  3. Run twine upload dist/* to upload to pypi repository
  4. Check the website https://pypi.org/project/armodel/ to find out it works or not

And more details can be found at https://packaging.python.org/

3. CLI

3.1. os-xdm-xlsx

Extract the Os Task information from os.xdm and then report all to Excel file.

os-xdm-xlsx data/Os.xdm data/Os.xlsx

Result:

  1. OsIsrs

  1. OsTasks

  1. OsScheduleTable

  1. OsCounter

3.2. rte-xdm-xlsx

Extract the Rte Configuration information from rte.xdm and then report all to Excel file.

  1. Export the Rte Configuration information to excel file
rte-xdm-xlsx data/Rte.xdm data/Rte.xlsx
  1. Export the Runnable Entities information to excel file
rte-xdm-xlsx -r data/Rte.xdm data/Os.xdm data/Runnable.xlsx

nvm-xdm-xlsx

Extract the NvM Configuration information from nvm.xdm and then report all to Excel file.

  1. Export the Nvm Configuration information to excel file
nvm-xdm-xlsx data/NvM.xdm data/NvM.xlsx

3.3. PrefSystemImporter

Read the EB preference XDM and generate the ARXML file list into text file or create the AUTOSAR builder project file.

$ pref-system-importer.exe -h
usage: pref-system-importer [-h] [-v] [--file-list] [--ab-project] [--base-path BASE_PATH] [--TRESOS_OUTPUT_BASE_DIR TRESOS_OUTPUT_BASE_DIR] [--project PROJECT] INPUTS [INPUTS ...] OUTPUT

positional arguments:
  INPUTS                The path of perf_imp_xxx.xdm.
  OUTPUT                The path of output file.

optional arguments:
  -h, --help            show this help message and exit
  -v, --verbose         print debug information.
  --file-list           generate the file list (Default)
  --ab-project          generate the AUTOSAR builder project
  --base-path BASE_PATH
                        base Path for EB tresos
  --env ENV [ENV ...]   specify the environment variable
  --project PROJECT     specify the project name

3.3.1. Configuration

h, help

Show the usage information

-v, --verbose

Print the extra debug information during execution.

--file-list or --ab-project

Generate ARXML file list text file or AUTOSAR builder project.

--base-path

Base path for the EB tresos project. For example: c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte

If the base path is specified, all input preference XDM configuration files will be based on this BasePath, which can solve the problem of the input preference configuration file name being too long.

--project

The project name will be generate in the AUTOSAR build project.

It is meaningless if you choose to generate ARXML file list text file.

--env

Replace the variable definition of ${env_var:xxx} which is defined in the EB preference XDM file.

3.3.2. Example

To generate the ARXML file list:

  • Base path: c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte
  • INPUT:
    • c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte/.prefs/pref_imp_exp_Imp_System.xdm
  • OUTPUT: output.lst
PrefSystemImporter --base-path c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte .prefs/pref_imp_exp_Imp_System.xdm output.lst 

To generate the AUTOSAR builder project:

All ARXML files in the .project file will use relative path names, so it is recommended to run PrefSystemImporter in the directory where the .project is located.

  • Base Path: c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte
  • INPUTs:
    • c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte/.prefs/pref_imp_exp_Bswm_rte.xdm
    • c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte/.prefs/pref_imp_exp_Imp_System.xdm
  • OUTPUT
    • c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte/ab_project/.project
  • Project Name: SimpleDemoRte
cd c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte/ab_project
PrefSystemImporter --base-path c:/EB/ACG-8_8_8_WIN32X86/workspace/simple_demo_rte --ab-project --project SimpleDemoRte .prefs/pref_imp_exp_Bswm_rte.xdm .prefs/pref_imp_exp_Imp_System.xdm .project 

4. Change History

Version 0.8.0

  1. Create the basic model for EB xdm. (Issue #1)
  2. Support to extract the Os Tasks/Isrs from EB xdm and store them in the excel files. (Issue #1)

Version 1.0.1

  1. Change the attribute to start with lowercase
  2. read_ref_value and read_optional_ref_value method returns EcucRefType.
  3. Read the OsScheduleTable and export to excel
  4. Read the OsCounter and export to excel

Version 1.0.2

  1. Fix the setOsAlarmCallbackName bug

Version 1.0.3

  1. Generate the System import file list based on EB preference Xdm.
  2. Add the support to read OsTaskAutostart element.
  3. Add the support to read OsTaskType element.

Version 1.1.1

  1. Add the support to append SystemMod/EcuExtract.arxml into list automatically for PrefSystemImporter.

Version 1.1.2

  1. Read the OsAppTaskRef from OsApplication.

Version 1.1.3

  1. Support to read Isr Priority and Vector for R52+ core.
  2. Export the Isr Priority and Vector to Excel.
  3. Read the OsAppResourceRef, OsAppIsrRef from OsApplication.

Version 1.1.4

  1. Fix the incorrect attribute of osTaskAutostart.
  2. Add the isOsTaskAutostart method to get the enabled flag of osTaskAutostart.
  3. Add the flake8 change rules.

Version 1.1.5

  1. Add the new interfaces to support to get the instance by name.
    • Rte::getRteBswModuleInstance
    • Rte::getRteBswModuleInstance

Version 1.1.6

  1. Add the OsResource support in Os Module:
    • Os::getOsResourceList
    • Os::addOsResource
  2. Read the NvMBlockDescriptor List

Version 1.1.7

  1. Solve the case issue of read_optional_value enables attribute.
  2. Support to read IMPORT_INFO for OsResource.
  3. Add the test cases for OsXdmParser.

Version 1.1.8

  1. Support to read NvM configuration from EB tresos Xdm file
  2. Export the NvM Configuration to excel file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

py_eb_model-1.1.8-py3-none-any.whl (51.0 kB view details)

Uploaded Python 3

File details

Details for the file py_eb_model-1.1.8-py3-none-any.whl.

File metadata

  • Download URL: py_eb_model-1.1.8-py3-none-any.whl
  • Upload date:
  • Size: 51.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.6

File hashes

Hashes for py_eb_model-1.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1da5f5ec14ad075a59f667481a169be334c993ae3d97a5f375ea14178752cf6d
MD5 3a1e14084357324dcaa4c472a6457f80
BLAKE2b-256 555d3024e5ea72e0fe3c6fb0f4122a2f2e43a0c918e478c62d7aa1e343054d59

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page