DATASHEET

HKMC C++ Rule Enforcement

Hyundai Motor Group - Secure C++ Coding Guide for Automotive Embedded System 
Version 4.1 

ENFORCEMENT HELIX QAC 2023.4

  

Total

a

Total Number of Rules

80

b

Total Number of ‘Not Statically Enforceable’ Rules (Assisted/Unassisted)

0

c

Total Number of Enforceable Rules (a-b)

80

d

Total Number of Enforced Rules

80

e

Total Number of Unenforced Rules

0

f

Enforce Rules Percentage (d/c)

100%

g

Unenforced Rules Percentage (e/c)

0%

Rule ID

Description

Enforced

3 Code Error

  

3.1 Preprocessor

  

P-DCL-001

Do not define a C-style variadic function

Yes

P-DCL-002

Do not declare or define a reserved identifier

Yes

P-DCL-003

Do not qualify a reference type with const or volatile

Yes

P-DCL-004

Do not write syntactically ambiguous declarations

Yes

P-DCL-005

Overload allocation and deallocation functions as a pair in the same scope

Yes

P-DCL-006

Attention of data leaks when passing class objects across trust boundaries

Yes

P-DCL-007

Do not reenter of function during initialization of static objects

Yes

P-DCL-008

Prevent termination due to exceptions in destructors or deallocation functions

Yes

P-DCL-009

Do not modify the standard namespaces

Yes

P-DCL-010

Do not define an unnamed namespace in a header file

Yes

P-DCL-011

Compliance of ODR (One-Definition Rule)

Yes

3.2 Integers, Characters and Strings

  

P-INT-001

Do not cast to an out-of-range enumeration value

Yes

P-STR-001

Guarantee that storage for strings has sufficient space for character data and the null terminator

Yes

P-STR-002

Do not create a std::string with a null pointer

Yes

P-STR-003

Do not use invalid references, pointers, and iterators when referencing to basic_string

Yes

P-STR-004

Range check required when accessing string

Yes

3.3 Expressions

  

P-EXP-001

Attention to the order of evaluation that causes the side effects

Yes

P-EXP-002

Do not delete an array through a pointer of the incorrect type

Yes

P-EXP-003

Attention to use expressions that do not evaluate(calculate) operands

Yes

P-EXP-004

Do not reference memory before initialized

Yes

P-EXP-005

Do not access an object of its lifetime

Yes

P-EXP-006

Do not access a CV variable through a CV (const or volatile) unqualified variable

Yes

P-EXP-007

Calling va_start requires passing an object of the appropriate type

Yes

P-EXP-008

Use offsetof() on valid types and members

Yes

P-EXP-009

Assurance that a lambda object is shorter than lifecycle of reference captured objects

Yes

P-EXP-010

Do not access the bits that are not part of the object’s value

Yes

P-EXP-011

Do not rely on the value of moved from object

Yes

3.4 Containers

  

P-CTR-001

Guarantee that container indices and iterators are within the valid range

Yes

P-CTR-002

Do not use valid references, pointer, and iterators to reference element of a container

Yes

P-CTR-003

Overflow protection required when copying data

Yes

P-CTR-004

Use valid iterator ranges

Yes

P-CTR-005

Do not subtract iterators that do not refer to the same container

Yes

P-CTR-006

Do not use an additive operator on an iterator if the result would overflow

Yes

P-CTR-007

Do not use pointer arithmetic on polymorphic objects

Yes

3.5 Exception Handling

  

P-ERR-001

Do not abruptly terminate the program

Yes

P-ERR-002

Need to handle all exceptions

Yes

P-ERR-003

Do not use setjmp() or longjmp()

Yes

P-ERR-004

Do not reference base classes or class data members in a constructor or destructor function-try-block handler

Yes

P-ERR-005

Exception handling in order from lowest class to highest class

Yes

P-ERR-006

Specify the exception exactly

Yes

P-ERR-007

Guarantee exception safety

Yes

P-ERR-008

Prevent to leak resources when handling exceptions

Yes

P-ERR-009

Handle all exceptions before main() begins executing

Yes

P-ERR-010

Catch exceptions by lvalue reference

Yes

P-ERR-011

Detect errors when converting a string to a number

Yes

P-ERR-012

Undetected exception handling

Yes

P-ERR-013

Catch declaration for common exceptions

Yes

P-ERR-014

Throw declarations for general exceptions

Yes

4 Code Quality

  

4.1 Memory Managements

  

P-MEM-001

Do not reference to deallocated memory

Yes

P-MEM-002

Properly deallocate dynamically allocated resources

Yes

P-MEM-003

Detect and handle memory allocation errors

Yes

P-MEM-004

Explicitly construct and destruct objects when manaing object lifecycle

Yes

P-MEM-005

Provide placement new with properly aligned pointers to sufficient storage capacity

Yes

P-MEM-006

Do not store an already-owned pointer value in an unrelated smart pointer

Yes

P-MEM-007

Memory release missing after lifetime

Yes

4.2 Object Oriented Programming

  

P-OOP-001

Do not invoke virtual functions from constructors or destructors

Yes

P-OOP-002

Do not slice derived objects

Yes

P-OOP-003

Do not delete a polymorphic object without a virtual destructor

Yes

P-OOP-004

Write constructor member initializers in the fixed order

Yes

P-OOP-005

Correctly handle self-copy assignment

Yes

P-OOP-006

Do not use pointer-to-member operators to access nonexistent members

Yes

P-OOP-007

Prefer special member functions and overloaded operators over the C standard library

Yes

P-OOP-008

Do not modify the source object in copy operators

Yes

P-OOP-009

Public static field do not mark as final

Yes

P-OOP-010

Important data element public declaration

Yes

P-OOP-011

Access critical private variables through public methods

Yes

4.3 Input and Output

  

P-FIO-001

Do not alternately input and output operations without calling intermediate positioning functions from the file stream

Yes

P-FIO-002

Close file pointers that are no longer needed

Yes

4.4 Concurrency

  

P-CON-001

Do not destroy a mutex while it is locked

Yes

P-CON-002

Unlocking mutex on exception

Yes

P-CON-003

Prevent data races when accessing bit-fields from multiple threads

Yes

P-CON-004

Prevent deadlock by locking mutex in predefined order

Yes

P-CON-005

Wrap function that can wake up falsely in a loop

Yes

P-CON-006

Protect thread safety and liveness when using condition variables

Yes

P-CON-007

Do not lock a non-recursive mutex that is already owned within the calling thread

Yes

5 Others Function

  

5.1 Using random number generator

  

P-MSC-001

Do not use std::rand() for generating pseudo random number

Yes

P-MSC-002

Proper seeding for random number generator

Yes

5.2 Return Value

  

P-MSC-003

Value returning function require returning values from all exit paths

Yes

P-MSC-004

Do not return from function declared [[noreturn]]

Yes

P-MSC-005

Return of stack variable address

Yes