Bug 194041

Summary: [JSC] Make disassembler data structures constant read-only data
Product: WebKit Reporter: Yusuke Suzuki <ysuzuki>
Component: New BugsAssignee: Yusuke Suzuki <ysuzuki>
Status: RESOLVED FIXED    
Severity: Normal CC: ews-watchlist, Hironori.Fujii, keith_miller, mark.lam, mcatanzaro, msaboff, saam, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=194085
Bug Depends on:    
Bug Blocks: 193606    
Attachments:
Description Flags
Patch mark.lam: review+

Yusuke Suzuki
Reported 2019-01-30 13:41:01 PST
[JSC] Make disassembler data structures constant ro data
Attachments
Patch (6.36 KB, patch)
2019-01-30 13:42 PST, Yusuke Suzuki
mark.lam: review+
Yusuke Suzuki
Comment 1 2019-01-30 13:42:26 PST
EWS Watchlist
Comment 2 2019-01-30 13:44:06 PST
Attachment 360611 [details] did not pass style-queue: ERROR: Source/JavaScriptCore/disassembler/udis86/ud_itab.py:252: whitespace after '(' [pep8/E201] [5] ERROR: Source/JavaScriptCore/disassembler/udis86/ud_itab.py:263: multiple statements on one line (semicolon) [pep8/E702] [5] ERROR: Source/JavaScriptCore/disassembler/udis86/ud_itab.py:263: whitespace after '(' [pep8/E201] [5] ERROR: Source/JavaScriptCore/disassembler/udis86/ud_itab.py:296: whitespace after '(' [pep8/E201] [5] ERROR: Source/JavaScriptCore/disassembler/udis86/ud_itab.py:326: whitespace after '(' [pep8/E201] [5] Total errors found: 5 in 7 files If any of these errors are false positives, please file a bug against check-webkit-style.
Mark Lam
Comment 3 2019-01-30 13:45:04 PST
Comment on attachment 360611 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=360611&action=review r=me > Source/JavaScriptCore/ChangeLog:3 > + [JSC] Make disassembler data structures constant ro data can you spell out read-only please?
Yusuke Suzuki
Comment 4 2019-01-30 13:45:37 PST
Comment on attachment 360611 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=360611&action=review >> Source/JavaScriptCore/ChangeLog:3 >> + [JSC] Make disassembler data structures constant ro data > > can you spell out read-only please? Fixed.
Yusuke Suzuki
Comment 5 2019-01-30 14:12:57 PST
Radar WebKit Bug Importer
Comment 6 2019-01-30 14:13:31 PST
Michael Catanzaro
Comment 7 2019-01-30 19:28:03 PST
Michael Catanzaro
Comment 8 2019-01-30 19:29:40 PST
(In reply to Michael Catanzaro from comment #7) > Committed r240755: <https://trac.webkit.org/changeset/240755> The output is kinda ugly: const struct ud_lookup_table_list_entry ud_lookup_table_list[] = { /* 000 */ { ud_itab__0, UD_TAB__OPC_TABLE, (const char* const)"opctbl" }, /* 001 */ { ud_itab__1, UD_TAB__OPC_MODE, (const char* const)"/m" }, /* 002 */ { ud_itab__2, UD_TAB__OPC_MODE, (const char* const)"/m" }, /* 003 */ { ud_itab__3, UD_TAB__OPC_MODE, (const char* const)"/m" }, /* 004 */ { ud_itab__4, UD_TAB__OPC_TABLE, (const char* const)"opctbl" }, etc. But it's needed to avoid: In file included from ../../Source/JavaScriptCore/disassembler/udis86/udis86_itab_holder.c:30: DerivedSources/JavaScriptCore/udis86_itab.c:2677:35: error: conflicting types for ‘ud_lookup_table_list’ struct ud_lookup_table_list_entry ud_lookup_table_list[] = { ^~~~~~~~~~~~~~~~~~~~ In file included from DerivedSources/JavaScriptCore/udis86_itab.c:2, from ../../Source/JavaScriptCore/disassembler/udis86/udis86_itab_holder.c:30: ../../Source/JavaScriptCore/disassembler/udis86/udis86_decode.h:189:48: note: previous declaration of ‘ud_lookup_table_list’ was here extern const struct ud_lookup_table_list_entry ud_lookup_table_list[]; ^~~~~~~~~~~~~~~~~~~~ In file included from ../../Source/JavaScriptCore/disassembler/udis86/udis86_itab_holder.c:30: DerivedSources/JavaScriptCore/udis86_itab.c:3272:22: error: conflicting types for ‘ud_itab’ struct ud_itab_entry ud_itab[] = { ^~~~~~~ In file included from DerivedSources/JavaScriptCore/udis86_itab.c:2, from ../../Source/JavaScriptCore/disassembler/udis86/udis86_itab_holder.c:30: ../../Source/JavaScriptCore/disassembler/udis86/udis86_decode.h:188:35: note: previous declaration of ‘ud_itab’ was here extern const struct ud_itab_entry ud_itab[]; ^~~~~~~
Fujii Hironori
Comment 9 2019-01-30 19:51:08 PST
Same error message was reported for WinCairo. https://build.webkit.org/builders/WinCairo%2064-bit%20WKL%20Release%20%28Build%29/builds/6570 They are solved by triggering Force Clean Build. https://build.webkit.org/builders/WinCairo%2064-bit%20WKL%20Release%20%28Build%29/builds/6581 Seems a Ninja incremental build issue.
Fujii Hironori
Comment 10 2019-01-30 19:59:28 PST
According to the GTK build log, it seems that udis86_itab_holder.c was recompiled without regenerating udis86_itab.c by invoking ud_itab.py. https://build.webkit.org/builders/GTK%20Linux%2064-bit%20Release%20%28Build%29/builds/18892/steps/compile-webkit/logs/stdio
Michael Catanzaro
Comment 11 2019-01-30 21:03:01 PST
Hmm, OK I tricked myself then; I manually deleted udis86_itab.c to test that change, just deleting it was probably enough. Indeed, changes to ud_itab.py don't result in a rebuild of the generated files. I'll rollout my "fix."
Michael Catanzaro
Comment 12 2019-01-30 21:04:36 PST
Reverted r240755 for reason: This was not correct Committed r240760: <https://trac.webkit.org/changeset/240760>
Michael Catanzaro
Comment 13 2019-01-30 21:10:00 PST
Triggered clean builds on all the WPE and GTK bots. Surprisingly, the JSCOnly bots don't seem to need it for some reason, not sure why.
Fujii Hironori
Comment 14 2019-01-30 22:08:18 PST
Because we have no JSCOnly x86 bots compiling UDIS86 code path. It seems difficult to attach a source dependency from ud_itab.py custom commad to udis86_itab_holder.c because it is difficult to determine which unified source bundle will includes udis86_itab_holder.c. Anyway, I think ud_itab.py won't be modified frequently.
Fujii Hironori
Comment 15 2019-01-31 01:45:44 PST
I'm wrong. C files are not bundled. File a new ticker Bug 194085 to the incremental Ninja build issue.
Note You need to log in before you can comment on or make changes to this bug.