Bug 103454

Summary: Typed Arrays should be part of JSC
Product: WebKit Reporter: Dominic Szablewski <dominic.szablewski>
Component: JavaScriptCoreAssignee: Nobody <webkit-unassigned>
Status: RESOLVED DUPLICATE    
Severity: Normal CC: ap, barraclough, fpizlo, isaacburns, oliver, tonikitoo
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   

Dominic Szablewski
Reported 2012-11-27 14:09:38 PST
It is my understanding that JSC (and v8?) have Typed Array support directly built-in, but it's just not exposed. I argue that Typed Arrays are much more part of the JavaScript language than they are of Webkit (or any browser for that matter). Many projects using JSC or v8 would greatly benefit from readily available Typed Arrays. It really should be a language feature. Typed Arrays have no external dependencies (unlike e.g. XMLHttpRequest) and could be easily exposed to JS code. For example, there are a number of projects out there trying to emulate Typed Arrays in NodeJS. My own project Ejecta ( http://impactjs.com/ejecta ) suffers from the lack of Typed Arrays when dealing with image data. Implementing the WebGL API on top of JSC is equally awkward ( https://github.com/vikerman/EjectaGL#note-on-typed-arrays-and-performance ). Typed Arrays should be exposed to JS and a native API for them should be provided.
Attachments
Gavin Barraclough
Comment 1 2012-11-29 23:55:29 PST
My understanding (Oliver may comment further) is that this is difficult, since Typed Arrays are defined by web specs rather than ECMA262, and are dependent on other types implemented in WebCore making them hard to move. That said, we've had a number of clients call for this – it would be really great to do so if we can.
Dominic Szablewski
Comment 2 2012-11-30 08:47:15 PST
I noticed that for the jsc command line tool, the Typed Arrays are actually exposed and can be used. This does not expose the prototype and some API methods, but I guess it's a testament that Typed Arrays really are fully defined internally in JSC itself. See jsc.cpp around line 224: addConstructableFunction(globalData, "Uint8Array", constructJSUint8Array, 1); ... I understand that Typed Arrays are not part of the ECMA spec, so maybe a compile switch for JSC could control if the API is exposed or not!?
Oliver Hunt
Comment 3 2012-11-30 09:28:54 PST
(In reply to comment #2) > I noticed that for the jsc command line tool, the Typed Arrays are actually exposed and can be used. This does not expose the prototype and some API methods, but I guess it's a testament that Typed Arrays really are fully defined internally in JSC itself. See jsc.cpp around line 224: > > addConstructableFunction(globalData, "Uint8Array", constructJSUint8Array, 1); > ... > > I understand that Typed Arrays are not part of the ECMA spec, so maybe a compile switch for JSC could control if the API is exposed or not!? No, jsc has internally defined a bunch of types that are sufficiently abi compatible for the engine to use them in place of the clusterfuck that is the w3c typed array spec. They don't have any of the necessary concepts to be used as the basis for the w3c typed arrays, and jsc can only support one or the other of these models.
Dominic Szablewski
Comment 4 2012-12-10 06:53:42 PST
Thanks for clarifying, Oliver! I had a hard time understanding how all the sources for typed arrays fit together. This is probably not the place to announce this, but I guess someone may find it useful: I've now made a version of JSC that directly includes Typed Arrays. It can be found here: https://github.com/phoboslab/JavaScriptCore-iOS/tree/typed-arrays This uses the compiled .idl files of the WebCore project as a basis; which is probably pretty stupid to begin with, but it seems to work just fine. I've also added some API methods to work with Typed Arrays directly in native code: https://github.com/phoboslab/JavaScriptCore-iOS/blob/typed-arrays/JavaScriptCore/API/JSTypedArray.h
Oliver Hunt
Comment 5 2012-12-10 07:44:54 PST
(In reply to comment #4) > Thanks for clarifying, Oliver! I had a hard time understanding how all the sources for typed arrays fit together. > > > This is probably not the place to announce this, but I guess someone may find it useful: I've now made a version of JSC that directly includes Typed Arrays. It can be found here: > > https://github.com/phoboslab/JavaScriptCore-iOS/tree/typed-arrays > > This uses the compiled .idl files of the WebCore project as a basis; which is probably pretty stupid to begin with, but it seems to work just fine. Yeah, I tried this originally but found it upsetting (esp. given the idl would have to stay in webcore for changes, etc yet still be correct in JSC) > > I've also added some API methods to work with Typed Arrays directly in native code: > > https://github.com/phoboslab/JavaScriptCore-iOS/blob/typed-arrays/JavaScriptCore/API/JSTypedArray.h I saw your announcement on twitter. I'm somewhat surprised at the performance gains you got without the JIT. --Oliver
Dominic Szablewski
Comment 6 2012-12-10 10:46:55 PST
(In reply to comment #5) > I saw your announcement on twitter. I'm somewhat surprised at the performance gains you got without the JIT. I don't know how big the performance difference in JavaScript itself is, but the bottleneck was always converting from and to JS through an API that wasn't made for this. We came up with a hack for Ejecta: Building a JSON string and using JSValueMakeFromJSONString was actually faster than creating an Array "by hand". See the ByteArrayToJSObject and JSObjectToByteArray functions here: https://github.com/phoboslab/Ejecta/blob/master/Source/Ejecta/EJConvert.m#L290
Filip Pizlo
Comment 7 2013-08-20 00:34:41 PDT
We implemented this recently. *** This bug has been marked as a duplicate of bug 119064 ***
Alexey Proskuryakov
Comment 8 2013-08-20 09:28:52 PDT
Phil, is it now possible to use typed arrays in projects that link to JavaScriptCore only, and don't create an HTML document? This is what this bug requested.
Oliver Hunt
Comment 9 2013-08-20 09:32:09 PDT
(In reply to comment #8) > Phil, is it now possible to use typed arrays in projects that link to JavaScriptCore only, and don't create an HTML document? This is what this bug requested. Yes. They're now present on the global object by default.
Isaac Burns
Comment 10 2014-05-21 14:53:48 PDT
(In reply to comment #9) > (In reply to comment #8) > > Phil, is it now possible to use typed arrays in projects that link to JavaScriptCore only, and don't create an HTML document? This is what this bug requested. > > Yes. They're now present on the global object by default. What Alexey P. is asking is if there is a way to access the data within a TypedArray object through the JSC API. For example, create and populate a Uint8Array in script, then pass the object to a native callback. There still is no way to access the buffer, as Dominic S. suggests.
Filip Pizlo
Comment 11 2014-05-21 14:56:53 PDT
(In reply to comment #10) > (In reply to comment #9) > > (In reply to comment #8) > > > Phil, is it now possible to use typed arrays in projects that link to JavaScriptCore only, and don't create an HTML document? This is what this bug requested. > > > > Yes. They're now present on the global object by default. > > What Alexey P. is asking is if there is a way to access the data within a TypedArray object through the JSC API. For example, create and populate a Uint8Array in script, then pass the object to a native callback. There still is no way to access the buffer, as Dominic S. suggests. That's correct. I agree that such a feature would be cool!
Alexey Proskuryakov
Comment 12 2014-05-21 15:57:39 PDT
Bug 120112 tracks adding more of an API, and buffer access in particular. I agree that it's appropriate to consider this bug resolved.
Isaac Burns
Comment 13 2014-05-23 07:29:15 PDT
Thanks for the note, Alexey. I will follow the new bug.
Note You need to log in before you can comment on or make changes to this bug.