vendorcode/amd/agesa/f16kb/*/PcieComplexDataKB.c: Implicit truncation
commitfb17a7de89b186de3f939690e547bd9f9fb9c746
authorEdward O'Callaghan <eocallaghan@alterapraxis.com>
Mon, 8 Dec 2014 16:39:13 +0000 (9 03:39 +1100)
committerEdward O'Callaghan <eocallaghan@alterapraxis.com>
Wed, 10 Dec 2014 07:09:26 +0000 (10 08:09 +0100)
treef090100452e1657d2c1063a831d71e600c81ff30
parent2d072d415b98804a3cbef5d2478050497b3e7a3d
vendorcode/amd/agesa/f16kb/*/PcieComplexDataKB.c: Implicit truncation

Clang complains:
 "implicit truncation from 'int' to bitfield changes value from -1 to 15"

-1 is define in 'c11std 6.3.1.3p2' as:

 [Signed and unsigned integers] Otherwise, if the new type is unsigned,
 the value is converted by repeatedly adding or subtracting one
 more than the maximum value that can be represented in the new type
 until the value is in the range of the new type.60)
 FOOTNOTE.60 The rules describe arithmetic on the mathem...

This is "0xFF" on Mullins and "0xF" in this case. Clang seems to
complain about this two's complement in a bitfield as being truncated.
As the bitfield is 4 bits wide, (a maximum of 15 decimal), we set the
field as '0x0F'. Ideally this field /should/ be set to 'UINT8_MAX' however
we still have silly truncation warnings.

Change-Id: Ib7476d453ffd932bb911e638117cf9f56f71f269
Signed-off-by: Edward O'Callaghan <eocallaghan@alterapraxis.com>
Reviewed-on: http://review.coreboot.org/7719
Reviewed-by: Alexandru Gagniuc <mr.nuke.me@gmail.com>
Tested-by: build bot (Jenkins)
src/vendorcode/amd/agesa/f16kb/Proc/GNB/Modules/GnbInitKB/PcieComplexDataKB.c