flat assembler
Message board for the users of flat assembler.
Index
> Linux > AMD's random number generator can't generate a 0 (+ app) |
| Author |
|
|
Jessé 11 May 2026, 05:13
Recently, while doing some assembly code to render data intro charts, and using 'rdrand' and 'rdseed' to provide that data to the displayed, I've figured out by accident what appears to be a bug (problem) only with AMD processors (maybe Zen2 only problem): they can't generate a number 0 at a given size! Running the same programs on an Intel processor, and the 0's are there with no problem.
You can help me figure out this by using my application to seek for any 0 number generated, and maybe post your results at this forum thread... I also must mention that this application is a very deep showcase on how to control and render data to the console screen at arbitrary positions, which I remember someone here was trying to achieve the same under Linux cli, and he asked for help on this subject before. Attached, I've provided that exact chart test application that showcases the AMD's RNG 0 problem: you'll probably, on an AMD host, never see the first bar change colors from green (which uses a TSC method I've created to generate random numbers), and also never see the base chart scale up from 0. On Intel processor, no problem, and the chart scale its base (minimum) beyond 0. The first bar renders how many zeroes are being generated by rdrand (red), rdseed (blue) and TSC-custom technique (green), as well as other bars render the other 65535 numbers from the 16-bit space. Note: it requires fastcall_v1 macro kit if anyone wants to compile and test it as is. Cheers!
|
|||||||||||
|
|
Jessé 11 May 2026, 05:16
So far, my results...
|
||||||||||
|
||||||||||
|
revolution 11 May 2026, 05:28
Do the lowest 16-bits ever equal all-zero for 32/64-bit outputs?
|
|||
|
|
revolution 11 May 2026, 05:41
I hope this is not something stupid from AMD that decided zero is not a random number.
Maybe some C?O person executed RDRAND, got zero, declared it was broken and made the engineers "fix" it. |
|||
|
|
Jessé 11 May 2026, 06:05
Haha, good point, I was thinking the same when this problem has presented itself to me.
I'll probably will e-mail AMD about this, and if they answered, I'll be back here to share what they said. |
|||
|
|
sylware 11 May 2026, 10:22
At the time I was wandering in information system security, there was that rule of thumb: never ever use hardware accelerated crypto...
|
|||
|
|
revolution 11 May 2026, 11:36
For trusted hardware: Hardware accelerated crypto is definitely the way to go IMO.
For untrusted hardware: Don't do any crypto with it, software or hardware. For best security with RDRAND, it might be backdoored, it might not. IDK, but never use it in isolation, always mix it with other sources. It doesn't hurt to add non-random data into an already random seed. It isn't possible to un-random a random value with non-randomness, it just mixes up the random bits a bit more. If the application isn't for crypto then none of this matters, use RDRAND for anything. Go for it. Last edited by revolution on 12 May 2026, 11:35; edited 1 time in total |
|||
|
|
sylware 11 May 2026, 12:31
'trusted hardware' does not exist, unless it is YOUR hardware, of YOUR design (based on best know how), with tight control of the manufacturing process.
|
|||
|
|
macomics 11 May 2026, 15:41
sylware wrote: 'trusted hardware' does not exist, unless it is YOUR hardware, of YOUR design (based on best know how), with tight control of the manufacturing process. |
|||
|
|
sylware 12 May 2026, 11:17
I said 'trusted hardware', not trusted hardware................
We all know "trusted" hardware does not exist, it is a spectrum: "trusted" is actually some amount of "trust" decided based on some contexts and specifics. At the time, when I was wandering in information system security groups: all this 'security hardware' was rumored to have flaws: entropy/maths/bugs/etc which users cannot cleanly fix, or actually even fix. |
|||
|
|
alCoPaUL 13 May 2026, 05:04
maybe because any number multiplied by zero is zero and any number divided by zero is overflow...
|
|||
|
< Last Thread | Next Thread > |
Forum Rules:
|
Copyright © 1999-2026, Tomasz Grysztar. Also on GitHub, YouTube.
Website powered by rwasa.