Skip to content

IMProject/IMUtility

IMUtility: A Safety-Critical Utility Code

Discord Shield Build Build codecov

About

The IMUtility (Incorporated MISRA Utility Code) originated as a sub-repository of the IMBootloader project. After a thorough review of the available safety-critical utility open-source projects in C, we realized that none of them met our standards. Therefore, we made the decision to create our own project and make it publicly available.

Our team has meticulously laid the foundation for everything necessary to ensure the code meets the rigorous standards required for safety-critical applications. Presently, we have incorporated unit tests using the Unity framework, code coverage using gcov/lcov, ensured code style conformance through Astyle formatting, and implemented cppcheck with all checks enabled. Additionally, we have enforced MISRA C 2012 checks using both cppcheck and ECLAIR, sponsored by Bugseng (last commit with ECLAIR analysis).

However, to further enhance the project's quality, we intend to achieve 100% coverage where feasible. This will serve as an additional layer of assurance that the code is of the highest quality and complies with safety-critical standards.

ECLAIR

ECLAIR version 3.13.1, is certified for use in safety-related development in compliance with the prescriptions of the following functional-safety standards:

  • ISO 26262 up to ASIL D
  • IEC 61508 up to SIL 4
  • EN 50128 up to SIL 4
  • EN 50657 up to SIL 4
  • IEC 62304 up to Class C
  • ISO 25119 up to SRL 3
  • ISO 19014 up to MPLr e

More info at its official web page https://www.bugseng.com/eclair.

For contributors

We are happy to see contributions. You can add utility code that you see is missing, improve existing one, or open issue tickets. Before you open PR:

  • write unit tests for your code
  • run make format
  • run make cppcheck
  • run make misra

After PR is opened, we will review your code, and after that code can be merged into the main branch.

Discord

Join us on the Discord channel https://discord.gg/R6nZxZqDH3

List of modules

Base64

  • Base64_encode
  • Base64_decode

Bit manipulation

  • BitManipulation_reflect
  • BitManipulation_bitSet
  • BitManipulation_setBit
  • BitManipulation_clearBit
  • BitManipulation_toggleBit
  • BitManipulation_rotl32

Crc8

  • Crc8Base_tableCalculator
  • Crc8Base // Base used for calculating all Crc8 variants
  • Crc8 // Basic Crc8, polynomial 0x07
  • Crc8_8h2f
  • Crc8_cdma2000
  • Crc8_darc
  • Crc8_dvbS2
  • Crc8_ebu
  • Crc8_icode
  • Crc8_itu
  • Crc8_maxim
  • Crc8_rohc
  • Crc8_SaeJ1850
  • Crc8_saeJ1850Zero
  • Crc8_wcdma

Crc16

  • Crc16Base_tableCalculator
  • Crc16Base // Base used for calculating all Crc16 variants
  • Crc16_a
  • Crc16_arc
  • Crc16_augCcit
  • Crc16_buypass
  • Crc16_ccitFalse
  • Crc16_ccitZero (XModem)
  • Crc16_cdma2000
  • Crc16_dds110
  • Crc16_dectR
  • Crc16_dectX
  • Crc16_dnp
  • Crc16_en13757
  • Crc16_genibus
  • Crc16_kermit
  • Crc16_maxim
  • Crc16_mcrf4xx
  • Crc16_modbus
  • Crc16_riello
  • Crc16_t10Dif
  • Crc16_teledisk
  • Crc16_tms37157
  • Crc16_usb
  • Crc16_x25

Crc32

  • Crc32Base_tableCalculator
  • Crc32Base // Base used for calculating all Crc32 variants
  • Crc32 // Basic Crc32
  • Crc32_bzip2
  • Crc32_c
  • Crc32_d
  • Crc32_jamcrc
  • Crc32_mpeg2
  • Crc32_posix
  • Crc32_q
  • Crc32_xfer

Cryptography

  • CaesarCipher_encrypt
  • CaesarCipher_decrypt
  • Chacha20_crypt
  • VernamCipher_encrypt
  • VernamCipher_decrypt

JSON

  • Json_startString
  • Json_addData
  • Json_endString
  • Json_findByKey

Map

  • Map_init
  • Map_insert
  • Map_getValue

Priority queue

  • PriorityQueue_init
  • PriorityQueue_empty
  • PriorityQueue_enqueue
  • PriorityQueue_dequeue

Queue

  • Queue_init
  • Queue_full
  • Queue_empty
  • Queue_enqueue
  • Queue_dequeue
  • Queue_front
  • Queue_rear

Scheduler

  • Scheduler_init
  • Scheduler_addTask
  • Scheduler_run

Sort algorithms

  • BubbleSort_sort
  • HeapSort_sort
  • InsertionSort_sort
  • MergeSort_sort
  • SelectionSort_sort

Utils

  • Utils_stringToUint32
  • Utils_swapElements
  • Utils_quickUint32Pow10
  • Utils_serialize8
  • Utils_deserialize8
  • Utils_serialize16BE
  • Utils_serialize24BE
  • Utils_serialize32BE
  • Utils_serializeBlobBE
  • Utils_deserialize16BE
  • Utils_deserialize24BE
  • Utils_deserialize32BE
  • Utils_deserializeBlobBE
  • Utils_serialize16LE
  • Utils_serialize24LE
  • Utils_serialize32LE
  • Utils_serializeBlobLE
  • Utils_deserialize16LE
  • Utils_deserialize24LE
  • Utils_deserialize32LE
  • Utils_deserializeBlobLE
  • Utils_isUpperChar
  • Utils_isLowerChar
  • Utils_isAlpha