Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement rule amendments from Technical Corrigenda 2 #841

Merged
merged 13 commits into from
Mar 18, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 7 additions & 7 deletions amendments.csv
Original file line number Diff line number Diff line change
Expand Up @@ -28,23 +28,23 @@ c,MISRA-C-2012,Amendment4,RULE-1-4,Yes,Replace,No,Easy
c,MISRA-C-2012,Amendment4,RULE-9-1,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Amendment4,RULE-9-2,Yes,Refine,No,Import
c,MISRA-C-2012,Corrigendum2,DIR-4-10,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-7-4,Yes,Refine,No,Easy
c,MISRA-C-2012,Corrigendum2,RULE-7-4,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Corrigendum2,RULE-8-2,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-8-3,Yes,Refine,No,Easy
c,MISRA-C-2012,Corrigendum2,RULE-8-3,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Corrigendum2,RULE-8-7,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-10-1,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-10-2,Yes,Refine,No,Easy
c,MISRA-C-2012,Corrigendum2,RULE-10-2,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Corrigendum2,RULE-10-3,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-11-3,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-11-6,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-13-2,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-13-6,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-14-3,Yes,Refine,No,Easy
c,MISRA-C-2012,Corrigendum2,RULE-14-3,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Corrigendum2,RULE-15-7,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-17-4,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-17-5,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-18-1,Yes,Refine,No,Easy
c,MISRA-C-2012,Corrigendum2,RULE-18-1,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Corrigendum2,RULE-20-14,No,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-21-19,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-21-20,Yes,Refine,No,Easy
c,MISRA-C-2012,Corrigendum2,RULE-22-9,Yes,Clarification,Yes,Import
c,MISRA-C-2012,Corrigendum2,RULE-21-20,Yes,Refine,Yes,Easy
c,MISRA-C-2012,Corrigendum2,RULE-22-9,Yes,Clarification,Yes,Import
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
| test.c:4:13:4:18 | ... + ... | Array pointer p2 points 1 element passed the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:5:13:5:18 | ... + ... | Array pointer p3 points 1 element passed the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:6:13:6:18 | & ... | Array pointer p4 points 1 element passed the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:11:8:11:11 | ... -- | Array pointer p7 points 1 element passed the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:12:8:12:9 | p3 | Array pointer p8 points 1 element passed the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:4:13:4:18 | ... + ... | Array pointer p2 points 1 element past the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:5:13:5:18 | ... + ... | Array pointer p3 points 1 element past the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:6:13:6:18 | & ... | Array pointer p4 points 1 element past the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:11:8:11:11 | ... -- | Array pointer p7 points 1 element past the end of $@. | test.c:2:7:2:8 | l1 | l1 |
| test.c:12:8:12:9 | p3 | Array pointer p8 points 1 element past the end of $@. | test.c:2:7:2:8 | l1 | l1 |
27 changes: 18 additions & 9 deletions c/misra/src/codingstandards/c/misra/EssentialTypes.qll
Original file line number Diff line number Diff line change
Expand Up @@ -328,12 +328,14 @@ class EssentialBinaryOperationSubjectToUsualConversions extends EssentialExpr, B
exists(
Type leftEssentialType, Type rightEssentialType,
EssentialTypeCategory leftEssentialTypeCategory,
EssentialTypeCategory rightEssentialTypeCategory
EssentialTypeCategory rightEssentialTypeCategory, int intTypeSize
|
leftEssentialType = getEssentialType(getLeftOperand()) and
rightEssentialType = getEssentialType(getRightOperand()) and
leftEssentialTypeCategory = getEssentialTypeCategory(leftEssentialType) and
rightEssentialTypeCategory = getEssentialTypeCategory(rightEssentialType)
rightEssentialTypeCategory = getEssentialTypeCategory(rightEssentialType) and
// For rules around addition/subtraction with char types:
intTypeSize = any(IntType i | i.isSigned()).getSize()
|
if
leftEssentialTypeCategory = rightEssentialTypeCategory and
Expand All @@ -356,14 +358,18 @@ class EssentialBinaryOperationSubjectToUsualConversions extends EssentialExpr, B
class EssentialAddExpr extends EssentialBinaryOperationSubjectToUsualConversions, AddExpr {
override Type getEssentialType() {
exists(
EssentialTypeCategory operandTypeCategory, EssentialTypeCategory otherOperandTypeCategory
Type otherOperandType, EssentialTypeCategory operandTypeCategory,
EssentialTypeCategory otherOperandTypeCategory, int intTypeSize
|
operandTypeCategory = getEssentialTypeCategory(getEssentialType(getAnOperand())) and
otherOperandTypeCategory = getEssentialTypeCategory(getEssentialType(getAnOperand()))
otherOperandType = getEssentialType(getAnOperand()) and
otherOperandTypeCategory = getEssentialTypeCategory(otherOperandType) and
intTypeSize = any(IntType i).getSize()
|
if
operandTypeCategory = EssentiallyCharacterType() and
otherOperandTypeCategory instanceof EssentiallySignedOrUnsignedType
otherOperandTypeCategory instanceof EssentiallySignedOrUnsignedType and
otherOperandType.getSize() <= intTypeSize
then result instanceof PlainCharType
else result = super.getEssentialType()
)
Expand All @@ -376,15 +382,18 @@ class EssentialAddExpr extends EssentialBinaryOperationSubjectToUsualConversions
class EssentialSubExpr extends EssentialBinaryOperationSubjectToUsualConversions, SubExpr {
override Type getEssentialType() {
exists(
EssentialTypeCategory leftEssentialTypeCategory,
EssentialTypeCategory rightEssentialTypeCategory
EssentialTypeCategory leftEssentialTypeCategory, Type rightEssentialType,
EssentialTypeCategory rightEssentialTypeCategory, int intTypeSize
|
leftEssentialTypeCategory = getEssentialTypeCategory(getEssentialType(getLeftOperand())) and
rightEssentialTypeCategory = getEssentialTypeCategory(getEssentialType(getRightOperand()))
rightEssentialType = getEssentialType(getRightOperand()) and
rightEssentialTypeCategory = getEssentialTypeCategory(rightEssentialType) and
intTypeSize = any(IntType i).getSize()
|
if
leftEssentialTypeCategory = EssentiallyCharacterType() and
rightEssentialTypeCategory instanceof EssentiallySignedOrUnsignedType
rightEssentialTypeCategory instanceof EssentiallySignedOrUnsignedType and
rightEssentialType.getSize() <= intTypeSize
then result instanceof PlainCharType
else result = super.getEssentialType()
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ where
// But the overall essential type is not essentially character type
getEssentialTypeCategory(getEssentialType(addOrSub)) = EssentiallyCharacterType()
or
// Or this is a subtration of one character with another, which is permitted, but produces an integral type
// Or this is a subtraction of one character with another, which is permitted, but produces an integral type
getEssentialTypeCategory(getEssentialType(addOrSub.getLeftOperand())) =
EssentiallyCharacterType() and
getEssentialTypeCategory(getEssentialType(addOrSub.getRightOperand())) =
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,19 @@
| test.c:15:3:15:11 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:16:3:16:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:17:3:17:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:18:3:18:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:19:3:19:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:20:3:20:10 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:21:3:21:10 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:27:3:27:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:28:3:28:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:29:3:29:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:30:3:30:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:31:3:31:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:32:3:32:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:33:3:33:10 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:34:3:34:10 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:19:3:19:11 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:20:3:20:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:21:3:21:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:22:3:22:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:23:3:23:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:24:3:24:10 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:25:3:25:10 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:28:3:28:9 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:29:3:29:10 | ... + ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:35:3:35:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:36:3:36:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:37:3:37:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:38:3:38:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:39:3:39:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:40:3:40:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:41:3:41:10 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:42:3:42:10 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:45:3:45:9 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
| test.c:46:3:46:10 | ... - ... | Expressions of essentially character type shall not be used inappropriately in addition and subtraction operations |
14 changes: 13 additions & 1 deletion c/misra/test/rules/RULE-10-2/test.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,10 @@ void testRules() {
enum E1 { A, B, C } e1 = A;
signed int i = 100;
unsigned int u = 100;
signed short s = 100;
unsigned short us = 100;
signed long l = 100L;
unsigned long ul = 100UL;
float f = 10.0f;

// Addition cases
Expand All @@ -19,8 +23,12 @@ void testRules() {
b + 'a'; // NON_COMPLIANT
'a' + e1; // NON_COMPLIANT
e1 + 'a'; // NON_COMPLIANT
'a' + s; // COMPLIANT
'a' + us; // COMPLIANT
'a' + l; // NON_COMPLIANT
'a' + ul; // NON_COMPLIANT

// Subtration cases
// Subtraction cases
'a' - i; // COMPLIANT
'a' - u; // COMPLIANT
'a' - 'a'; // COMPLIANT
Expand All @@ -32,4 +40,8 @@ void testRules() {
'a' - b; // NON_COMPLIANT
e1 - 'a'; // NON_COMPLIANT
'a' - e1; // NON_COMPLIANT
'a' - s; // COMPLIANT
'a' - us; // COMPLIANT
'a' - l; // NON_COMPLIANT
'a' - ul; // NON_COMPLIANT
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,4 @@
| test.c:27:10:27:14 | ... < ... | Controlling expression in loop statement has an invariant value. |
| test.c:37:3:37:6 | 1 | Controlling expression in conditional statement has an invariant value. |
| test.c:38:3:38:3 | 1 | Controlling expression in conditional statement has an invariant value. |
| test.c:45:10:45:26 | ... && ... | Controlling expression in loop statement has an invariant value. |
7 changes: 7 additions & 0 deletions c/misra/test/rules/RULE-14-3/test.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,4 +37,11 @@ void f5(bool b1) {
true ? 1 : 2; // NON_COMPLIANT
1 ? 1 : 2; // NON_COMPLIANT
b1 ? 1 : 2; // COMPLIANT
}

void f6(int p1) {
while (p1 < 10 && p1 > 12) { // NON_COMPLIANT[FALSE_NEGATIVE]
}
while (1 == 0 && p1 > 12) { // NON_COMPLIANT
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,4 @@
| test.c:58:5:58:22 | return ... | wchar_t * function w_sample3 is returning a string literal. |
| test.c:69:3:69:9 | call to sample4 | char * parameter of sample4 is passed a string literal. |
| test.c:78:3:78:11 | call to w_sample4 | wchar_t * parameter of w_sample4 is passed a string literal. |
| test.c:91:3:91:11 | call to w_sample7 | char * parameter of w_sample7 is passed a string literal. |
12 changes: 12 additions & 0 deletions c/misra/test/rules/RULE-7-4/test.c
Original file line number Diff line number Diff line change
Expand Up @@ -79,4 +79,16 @@ void w_call45() {
w_sample5(L"string9"); // COMPLIANT: passing string literal to const char*
}

void w_sample6(int x, ...) {}

void w_call6() {
w_sample6(1, "string10"); // COMPLIANT by first (and only) exception
}

void w_sample7(char *x, ...) {}

void w_call7() {
w_sample7("string11", 1); // NON_COMPLIANT, does not fit exceptional case
}

int main() { return 0; }
4 changes: 4 additions & 0 deletions c/misra/test/rules/RULE-8-3/function1.c
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,8 @@ a f21(wi w, wi h) { // NON_COMPLIANT

void f22(int f22b, int f22a) { // NON_COMPLIANT
return;
}

void f23(int f23a) { // COMPLIANT
return;
}
4 changes: 3 additions & 1 deletion c/misra/test/rules/RULE-8-3/function2.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,6 @@ typedef long a;

extern a f21(wi w, hi h); // NON_COMPLIANT

extern void f22(int f22a, int f22b); // NON_COMPLIANT
extern void f22(int f22a, int f22b); // NON_COMPLIANT

extern void f23(int); // COMPLIANT
12 changes: 12 additions & 0 deletions change_notes/2025-1-04-misra-c-technical-corrigenda-2.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
- `RULE-8-3` - `DeclarationsOfAFunctionSameNameAndType.ql`:
- Implement new exception, unnamed parameters are not covered by this rule.
- `RULE-10-2` - `AdditionSubtractionOnEssentiallyCharType.ql`:
- Disallow `+` and `-` operations with an essentially char type and other types larger than int type.
- Note, this change affects the essential type of such expressions, which may affect other essential types rules.
- `RULE-18-1`, `M5-0-16` - `PointerAndDerivedPointerMustAddressSameArray.ql`, `PointerAndDerivedPointerAccessDifferentArray.ql`:
- Treat casts to byte pointers as pointers to arrays of the size of the pointed-to type.
- Fix typo in report message, "passed" replaced with "past."
- Suppress results where range analysis appears potentially unreliable.
- `RULE-21-10`, `RULE-25-5-3`, `ENV34-C` - `CallToSetlocaleInvalidatesOldPointers.ql`, `CallToSetlocaleInvalidatesOldPointersMisra.ql`, `DoNotStorePointersReturnedByEnvFunctions.ql`:
- Report usage of returned pointers from `asctime`, `ctime`, during a call to either of the former.
- Report usage of returned pointers from `gmtime`, `localtime`, during a call to either of the former.
8 changes: 4 additions & 4 deletions cpp/common/src/codingstandards/cpp/Compatible.qll
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,10 @@ predicate parameterTypesIncompatible(FunctionDeclarationEntry f1, FunctionDeclar

predicate parameterNamesIncompatible(FunctionDeclarationEntry f1, FunctionDeclarationEntry f2) {
f1.getDeclaration() = f2.getDeclaration() and
exists(ParameterDeclarationEntry p1, ParameterDeclarationEntry p2, int i |
p1 = f1.getParameterDeclarationEntry(i) and
p2 = f2.getParameterDeclarationEntry(i)
exists(string p1Name, string p2Name, int i |
p1Name = f1.getParameterDeclarationEntry(i).getName() and
p2Name = f2.getParameterDeclarationEntry(i).getName()
|
not p1.getName() = p2.getName()
not p1Name = p2Name
)
}
Loading
Loading