2013/11/25 Guy Harris <g...@alum.mit.edu>:
>
> On Nov 24, 2013, at 5:37 PM, Bálint Réczey <bal...@balintreczey.hu> wrote:
>
>> I tried to trigger a crash using GCC and -ftrapv without success while
>> the clang-compiled binary crashed as expected:
>
> Reproduced with clang on (x86-64) OS X.
>
> The problem is in
>
>         PRIVATE int strhash(const char *x)
>         {
>           int h = 0;
>           while( *x) h = h*13 + *(x++);
>           return h;
>         }
>
> In practice, the result of the hash function is taken modulo the hash table 
> size, and that's always done with &, so, in practice, it's safe if it 
> overflows.
>
> Perhaps it should do the calculation with unsigned integers and return an 
> unsigned integer, however.
Yes, signed int overflow yields undefined behaviour, but the result of
unsigned overflow is defined thus the code above is invalid C.
At least we (you) found a real problem by temporarily enabling the
broken -ftrapv.  :-)

Cheers,
Balint
___________________________________________________________________________
Sent via:    Wireshark-dev mailing list <wireshark-dev@wireshark.org>
Archives:    http://www.wireshark.org/lists/wireshark-dev
Unsubscribe: https://wireshark.org/mailman/options/wireshark-dev
             mailto:wireshark-dev-requ...@wireshark.org?subject=unsubscribe

Reply via email to