Opened 2 years ago
Last modified 12 months ago
#17863 new bug
WebPositive crashes on overuse of Date.getMilliseconds()
Reported by: | thebuck | Owned by: | pulkomandy |
---|---|---|---|
Priority: | normal | Milestone: | Unscheduled |
Component: | Kits/Web Kit | Version: | R1/Development |
Keywords: | Cc: | ||
Blocked By: | Blocking: | ||
Platform: | x86-64 |
Description
To reproduce: Call the getMilliseconds method of Date regularly (JavaScript).
This will crash WebPositive reliably after a number of calls with the number heavily depending on the call frequency employed.
Attachments (2)
Change History (9)
by , 2 years ago
Attachment: | timetest.html added |
---|
comment:1 by , 2 years ago
Besides, the maximum reachable frequency when using setInterval()
callbacks was at roughly 30 per second for me, even for pure calculation tasks without drawing. Pretty slow.
comment:2 by , 2 years ago
Oops, just tried on Linux in a WebKit-based browser: same result, exactly 60! Generic WebKit bug!
follow-up: 4 comment:3 by , 2 years ago
The low precision is intentional on webkit side, to prevent javascript gode to perform spectre/meltdown type of attacks that rely on precise timing measurements.
If the crash is generic webkit, maybe report it in the webkit bugtracker instead?
comment:4 by , 2 years ago
If the crash is generic webkit, maybe report it in the webkit bugtracker instead?
Rather not. I now suspect it to be machine/CPU-dependant:
- could not reproduce on any other machine
GLTeapot demo fires crash reporter up instantly, but continues to rotate... That app repeatedly measures time, right?
I will try to find out which time measurement function it calls and write a little while(1) get_the_time();
test.
follow-up: 6 comment:5 by , 2 years ago
GLTeapot is known to be unstable, that is almost certainly totally unrelated to timekeeping. Plenty of other applications fetch the time rapidly.
by , 2 years ago
Attachment: | timetest.c added |
---|
comment:6 by , 2 years ago
comment:7 by , 12 months ago
Component: | Applications/WebPositive → Kits/Web Kit |
---|---|
Priority: | high → normal |
For me, on hrev56334 x86_64, this crashes it after about 60 calls. Feel free to adjust the for-loop iterations (10 by now).