[Date Prev][Date Next] [Chronological] [Thread] [Top]

Re: (ITS#8230) [PATCH] totp: bug fixes and improvements



Peter Marschall wrote:

>>>       For the big-endian case, 'msg' wasn't set from 'tval' in generate().
>>
>> This patch is wrong, as I commented on github.
> Are you sure?
>
> Please note the run index i changed direction, which causes different results
> because of  >>=.
>
> In my tests [double checked before sending this mail] on an amd64 [little-
> endian architecture], the patched version converts 0x3837363534333231 to
> - "87654321"	in the !WORDS_BIGENDIAN case [unchanged]
> - "12345678"	in the WORDS_BIGENDIAN case
> [using the fact that  0x3N = "N"  for 0 <= N <=9]
> To me that looks correct.
>
> What issues did you see exactly?

That is exactly wrong. Given any integer input the string should be identical 
regardless of endianness. It should be "87654321" in both cases. With your 
patch, hashes will be incompatible between different machine architectures.

-- 
   -- Howard Chu
   CTO, Symas Corp.           http://www.symas.com
   Director, Highland Sun     http://highlandsun.com/hyc/
   Chief Architect, OpenLDAP  http://www.openldap.org/project/