[clang] [compiler-rt] [clang][UBSan] Add implicit conversion check for bitfields (PR #75481)

Axel Lundberg via llvm-commits llvm-commits at lists.llvm.org
Wed Feb 7 06:55:15 PST 2024


Zonotora wrote:

Hi again, I have now finally gotten time and updated the patch so that the unnecessary emits I mentioned in the initial commit are avoided. The current patch introduces a number of new fsanitizer flags to separate integer conversions from bitfield conversions. E.g., 

- ``-fsanitize=implicit-unsigned-bitfield-truncation``
- ``-fsanitize=implicit-signed-bitfield-truncation``
- ``-fsanitize=implicit-bitfield-sign-change``
- ``-fsanitize=implicit-bitfield-truncation``
- ``-fsanitize=implicit-bitfield-arithmetic-value-change``
- ``-fsanitize=implicit-bitfield-conversion``
- ``-fsanitize=implicit-integer-conversion`` <---- This used to be ``-fsanitize=implicit-conversion``

``-fsanitize=implicit-conversion`` will now represent ``-fsanitize=implicit-integer-conversion`` and ``-fsanitize=implicit-bitfield-conversion``.

Previously the following:
```c
typedef struct {
    unsigned char a:4;
} X;

int main(void) {
    X x;
    unsigned int a = 272;
    x.a = a;
    return 0;
}
```
emitted a implict integer conversion error in the assignment of `x.a = a` with the ``-fsanitize=implicit-integer-conversion``. This is no longer the case as the assignment involves bitfields. To get the emission error, one would have to include the ``-fsanitize=implicit-bitfield-conversion`` flag instead.

I have compiled clang with the -fsanitizer flag ``-fsanitize=implicit-bitfield-conversion`` without any problems. What are your thoughts on this new change? @vitalybuka @AaronBallman @LebedevRI @efriedma-quic

https://github.com/llvm/llvm-project/pull/75481


More information about the llvm-commits mailing list