Bug 88315

Summary: [GTK] Enable the LLInt
Product: WebKit Reporter: Andy Wingo <wingo>
Component: JavaScriptCoreAssignee: Andy Wingo <wingo>
Status: RESOLVED FIXED    
Severity: Normal CC: ap, fpizlo, gustavo, mrobinson, philn, xan.lopez
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
again with the Makefile foo
none
fourth time's the charm
none
fifth time's the... (more makefile foo) none

Andy Wingo
Reported 2012-06-05 01:50:07 PDT
The patch to be attached will enable the LLInt for the GTK+ port.
Attachments
Patch (11.84 KB, patch)
2012-06-05 02:14 PDT, Andy Wingo
no flags
Patch (11.95 KB, patch)
2012-06-05 02:48 PDT, Andy Wingo
no flags
again with the Makefile foo (11.94 KB, patch)
2012-06-05 03:07 PDT, Andy Wingo
no flags
fourth time's the charm (12.08 KB, patch)
2012-06-05 03:28 PDT, Andy Wingo
no flags
fifth time's the... (more makefile foo) (12.14 KB, patch)
2012-06-05 03:40 PDT, Andy Wingo
no flags
Andy Wingo
Comment 1 2012-06-05 02:14:08 PDT
Andy Wingo
Comment 2 2012-06-05 02:16:43 PDT
The patch includes changes to Platform.h that I hope don't affect anyone, but need some checking from Apple folks for their ports. I would also appreciate it if Filip could verify that the changes to LowLevelInterpreter.asm and asm.rb are sane. Thanks!
Andy Wingo
Comment 3 2012-06-05 02:48:04 PDT
Andy Wingo
Comment 4 2012-06-05 03:07:47 PDT
Created attachment 145742 [details] again with the Makefile foo
Andy Wingo
Comment 5 2012-06-05 03:28:10 PDT
Created attachment 145745 [details] fourth time's the charm
Andy Wingo
Comment 6 2012-06-05 03:40:52 PDT
Created attachment 145749 [details] fifth time's the... (more makefile foo)
Filip Pizlo
Comment 7 2012-06-05 21:20:23 PDT
Comment on attachment 145749 [details] fifth time's the... (more makefile foo) Looks right!
Filip Pizlo
Comment 8 2012-06-05 21:27:13 PDT
Comment on attachment 145749 [details] fifth time's the... (more makefile foo) View in context: https://bugs.webkit.org/attachment.cgi?id=145749&action=review My additional comments should not be viewed as commit blockers. Just giving you stuff to think about, possibly for future patches. > Source/JavaScriptCore/llint/LowLevelInterpreter.asm:106 > - storei 0, 0xbbadbeef[] > + storei t0, 0xbbadbeef[] Actually, why? To clarify, this looks like it's fine, but unnecessary. I'm curious why you needed to do this. On all of the backends supported by offlineasm, 'storei 0, 0xbbadbeef[]' should be supported. On x86 it's a single mov instruction. Same for x86_64. On ARMv7, it'll create some temporary registers for the immediate 0 and the address 0xbbadbeef. But that should all work. If it doesn't, then it's a pretty fundamental bug! > Source/JavaScriptCore/offlineasm/asm.rb:100 > - "\" SYMBOL_STRING(#{labelName}) \"" > + "\" SYMBOL_STRING_RELOCATION(#{labelName}) \"" Looks right, sort of. This makes me worry that on Linux you'll end up taking indirections whenever LLInt jumps at one of its own labels. But maybe I don't do that enough for it to matter? > Source/WTF/wtf/InlineASM.h:79 > +#elif OS(LINUX) > +#define LOCAL_LABEL_STRING(name) ".L" #name LGTM.
Andy Wingo
Comment 9 2012-06-06 08:10:53 PDT
Thanks for the review and comments. (In reply to comment #8) > > Source/JavaScriptCore/llint/LowLevelInterpreter.asm:106 > > - storei 0, 0xbbadbeef[] > > + storei t0, 0xbbadbeef[] > > Actually, why? The immediate symptom is that the generated assembly causes a compile error: The assembly: (Line 6 is the movl) OFFLINE_ASM_GLOBAL_LABEL(llint_begin) "\tmovl $0, 3148725999\n" // ../../Source/JavaScriptCore/llint/LowLevelInterpreter.asm:106 "\txorq %rax, %rax\n" // ../../Source/JavaScriptCore/llint/LowLevelInterpreter.asm:107 "\tcall *%rax\n" // ../../Source/JavaScriptCore/llint/LowLevelInterpreter.asm:108 The error: /tmp/cczM4iOQ.s: Assembler messages: /tmp/cczM4iOQ.s:6: Error: unsupported for `mov' /tmp/cczM4iOQ.s:4386: Error: unsupported for `mov' Pretty strange stuff; I've thought over it a while but I don't have any coherent explanation. I assume you do make x86-64 builds, yes? > > Source/JavaScriptCore/offlineasm/asm.rb:100 > > - "\" SYMBOL_STRING(#{labelName}) \"" > > + "\" SYMBOL_STRING_RELOCATION(#{labelName}) \"" > > Looks right, sort of. This makes me worry that on Linux you'll end up taking indirections whenever LLInt jumps at one of its own labels. But maybe I don't do that enough for it to matter? Yeah it's a bit irritating. I think that although we were compiling with -fvisibility=hidden for other parts of webkit, somehow we dropped that for JSC. I'm looking into that.
Andy Wingo
Comment 10 2012-06-06 08:40:51 PDT
Replying to myself. (In reply to comment #9) > I think that although we were compiling with -fvisibility=hidden for other parts of webkit, somehow we dropped that for JSC. I'm looking into that. Yes, the GTK+ port did some bone-headed things there (bug 88421). It will take some time to extricate, though, so it seems we will have to do the PLT indirection dance for some intermediate amount of time.
Andy Wingo
Comment 11 2012-06-06 09:00:50 PDT
Comment on attachment 145749 [details] fifth time's the... (more makefile foo) Clearing flags on attachment: 145749 Committed r119593: <http://trac.webkit.org/changeset/119593>
Andy Wingo
Comment 12 2012-06-06 09:01:01 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.