•  


Suspicious add with sizeof — CodeQL query help documentation CodeQL docs

Suspicious add with sizeof

ID: cpp/suspicious-add-sizeof
Kind: problem
Security severity: 8.8
Severity: warning
Precision: high
Tags:
   - security
   - external/cwe/cwe-468
Query suites:
   - cpp-code-scanning.qls
   - cpp-security-extended.qls
   - cpp-security-and-quality.qls

Click to see the query in the CodeQL repository

Pointer arithmetic in C and C++ is automatically scaled according to the size of the data type. For example, if the type of p is T* and sizeof(T) == 4 then the expression p+1 adds 4 bytes to p .

This query finds code of the form p + k*sizeof(T) . Such code is usually a mistake because there is no need to manually scale the offset by sizeof(T) .

Recommendation

  1. Whenever possible, use the array subscript operator rather than pointer arithmetic. For example, replace *(p+k) with p[k] .

  2. Cast to the correct type before using pointer arithmetic. For example, if the type of p is char* but it really points to an array of type double[] then use the syntax (double*)p + k to get a pointer to the k ’th element of the array.

Example

int
 example1
(
int
 i
)
 {

  int
 intArray
[
10
]
 =
 {
 1
,
 2
,
 3
,
 4
,
 5
,
 6
,
 7
,
 8
,
 9
,
 10
 };

  int
 *
intPointer
 =
 intArray
;

  // BAD: the offset is already automatically scaled by sizeof(int),

  // so this code will compute the wrong offset.

  return
 *
(
intPointer
 +
 (
i
 *
 sizeof
(
int
)));

}


int
 example2
(
int
 i
)
 {

  int
 intArray
[
10
]
 =
 {
 1
,
 2
,
 3
,
 4
,
 5
,
 6
,
 7
,
 8
,
 9
,
 10
 };

  int
 *
intPointer
 =
 intArray
;

  // GOOD: the offset is automatically scaled by sizeof(int).

  return
 *
(
intPointer
 +
 i
);

}

References

  • Common Weakness Enumeration: CWE-468 .

  • © GitHub, Inc.
  • Terms
  • Privacy
- "漢字路" 한글한자자동변환 서비스는 교육부 고전문헌국역지원사업의 지원으로 구축되었습니다.
- "漢字路" 한글한자자동변환 서비스는 전통문화연구회 "울산대학교한국어처리연구실 옥철영(IT융합전공)교수팀"에서 개발한 한글한자자동변환기를 바탕하여 지속적으로 공동 연구 개발하고 있는 서비스입니다.
- 현재 고유명사(인명, 지명등)을 비롯한 여러 변환오류가 있으며 이를 해결하고자 많은 연구 개발을 진행하고자 하고 있습니다. 이를 인지하시고 다른 곳에서 인용시 한자 변환 결과를 한번 더 검토하시고 사용해 주시기 바랍니다.
- 변환오류 및 건의,문의사항은 juntong@juntong.or.kr로 메일로 보내주시면 감사하겠습니다. .
Copyright ⓒ 2020 By '전통문화연구회(傳統文化硏究會)' All Rights reserved.
 한국   대만   중국   일본