So this a exercise from the book COMPUTERS SYSTEMS A PROGRAMMERS PERSPECTIVE  
I need to add two signed numbers and in case it overflows or underflows return
The book imposes a set of rules that the solution must follow :
Forbidden:
My code
I need to add two signed numbers and in case it overflows or underflows return
TMAX (011..1b) or TMIN (100..0b) respectively. In this case we can assumed two's complement representation.  The book imposes a set of rules that the solution must follow :
Forbidden:
- Conditionals, loops, function calls and macros.
- Division, modulus and multiplication.
- Relative comparison operators (<,>,<=and>=).
- All bit level and logic operations.
- Left and right shifts, but only with shift amounts between 0 and w - 1
- Addition and subtraction.
- Equality (==) and inequality (!=) tests.
- Casting between intandunsigned.
My code
| 1 2 3 4 5 6 7 8 | int saturating_add(int x, int y) { int sum = (unsigned int)x + y; int w = (sizeof(int) << 3) - 1; int mask = (~(x ^ y) & (x ^ sum)) >> w; int max_min = (1 << w) ^ (sum >> w); return (~mask & sum) + (mask & max_min); } | 
