Thread Rating:
  • 0 Vote(s) - 0 Average
  • 1
  • 2
  • 3
  • 4
  • 5
-32768 on 16-bit targets
#1
Just to make sure since several of our customers brought this up lately:

Is the following code compliant on a target where 'int' is 16 bits?

Code:
int16_t x = -32768;

Since the standard C type of '-32768' is 'long' on 16-bit targets, the essential type is the same.
Thus, I believe the code is not compliant.

This seems unfortunate given that the value does fit in the target type; especially since the same code is compliant on targets with 32-bit int.
<t></t>
Reply
#2
You are correct to say that the code is not-compliant.

The C standard type is "signed long", since it is the result of a unary negation on a literal whose type is "signed long".

The essential type and C standard type of an expression may only differ if the C standard type is "int" or "unsigned int". This is not the situation, so the essential type is also "signed long".

Using INT_MIN from the limits.h will return an expression with the correct value and "signed int" type.
Posted by and on behalf of the MISRA C Working Group
Reply


Forum Jump:


Users browsing this thread: 1 Guest(s)