On Wed, Jun 19, 2013 at 12:51:33PM +0200, Szabolcs Nagy wrote: > * stateless <statel...@archlinux.us> [2013-06-19 11:38:00 +0100]: > > This is a version of md5sum(1) using the md5 routines from 9base - slightly > > adapted to compile. > > > > be careful with integer arithmetics in crypto code > > your code invokes undefined behaviour because of > signed int overflow: > > unsigned f(unsigned char c) { return c<<24; } > > c is promoted to int not unsigned in the left shift > > it will work in practice (usually) but that's only > by accident > > you should cast c to the right type
You are right. I will send some incremental patches to fix this (and for 9base too). I presume this is in the utils/md5*.c code which I have not looked at in anger yet. Integer promotion rules are nasty! I think something like the following would still be ok? unsigned f(unsigned int c) { return c<<24U; } Thanks, stateless