logoalt Hacker News

Saying goodbye to asm.js

295 pointsby eqriontoday at 12:01 PM129 commentsview on HN

Comments

pjmlptoday at 2:35 PM

> asm.js was Mozilla’s response to the question posed by NaCl and PNaCl: how can the web run code at native speeds?

Had it been today, Chrome would have just pushed NaCl and PNaCl no matter what, and then everyone would complain why Safari and Firefox aren't keeping up with "Web" standards.

show 3 replies
rudi-ctoday at 2:38 PM

That's sad but sensical. Fun fact, Figma originally started as a fully C++ codebase, and Asm.js was key in proving that it would be possible to run a design tool in the browser. The switch to WebAssembly didn't happen until after there were paying customers, and provided nice improvements to load time (Asm.js is still JS which the bundle size is bigger and requires the code to be parsed into an AST, unlike WASM).

show 2 replies
futunetoday at 2:06 PM

So the death of asm.js is upon us? We are drifting away from the timeline of the prophecy:

https://www.destroyallsoftware.com/talks/the-birth-and-death...

(And to those who haven't encountered this before, I strongly recommend a watch. It may be the greatest tech talk of all time, for certain values of greatest.)

show 5 replies
metmactoday at 1:58 PM

I’ll never forget watching Gary Bernhardt give his talk on JavaScript.[0] Was my introduction to asm.js, and the rabbithole associated with compiling code to run in the browser.

12 years on, it’s shocking how much of his fiction became reality.

[0] https://www.destroyallsoftware.com/talks/the-birth-and-death...

show 1 reply
ndesaulnierstoday at 5:02 PM

A long time ago, I wrote a small chapter in a WebGL book on asm.js.

https://webglinsights.github.io/

It was fun to see the rise of asm.js, which was a precursor to Web Assembly. Some of the early demos were so cool to see; Unreal Engine running in the browser. :) Bitter sweet to see the sun set here, but it did lead to much better things.

sehuggtoday at 2:12 PM

Hmmm, need a asm.js -> WASM transpiler maybe.

(compiling legacy code with legacy versions of Emscripten is quite frustrating, almost as bad as updating your JS code to be compatible with accumulated changes in the Emscripten ABI)

show 2 replies
drob518today at 1:39 PM

Asm.js is dead! Long live WebAssembly!

show 2 replies
andrewl-hntoday at 7:30 PM

I remember when Mozilla released OdinMonkey that was hyper-specialized for asm.js code, the Chrome / V8 team instead worked on general-purpose optimizations in their JIT that would run normal JavaScript faster but also would help asm.js. The difference in speed was 2-4x in favor of Firefox, and they hyped it a lot :D

Nowadays most browser JavaScript VMs converged to very similar designs and optimizations, so even without Odin asm.js code would run pretty fast anyway.

looneysquashtoday at 2:09 PM

I personally think this is a mistake. But I'm not sure how much it matters. It's not like a lot of people were using asm.js still AFAIK.

But wasm is too isolated from javascript. From my limited use of it, I was considering trying to compile to asmjs instead.

But I wasn't sure that emscripten still fully supported it.

You can't call most web apis from wasm.

But more important for what i was trying to do, you can't zero copy buffers from js to wasm.

Everything is a trade off. The isolation is a good thing, but also a bad thing.

show 3 replies
trgntoday at 7:52 PM

:(

this was such a crazy project. remember when we compiled our c++ to wasm over 10 years ago, wait, this works?! web seemed to move so fast then.

hollowturtletoday at 4:57 PM

Isn't Asm.js better just for the fact that I can call web apis directly without shims? Or moving data in and out? I'd love to commit totally to webassembly but still seems very limited, am I wrong?

show 2 replies
stkdumptoday at 1:30 PM

There goes my plan to use js code generation at runtime to make my algorithms faster. Doing this with wasm will be much harder.

show 5 replies
koolalatoday at 1:11 PM

Never saw those monkey prints before

https://monkeyink.com/ink/blog/archives/2016/08/_this_is_a_f...

"The image is a collage of antique open source art reflecting the open source code."

show 1 reply
EdwardDiegotoday at 2:38 PM

We'll drink again in Valhalla (not the JDK project, the one with much carousing).

karel-3dtoday at 7:56 PM

What I liked about asm.js is that it's "just" javascript and you don't need any special way to load them, while with wasm you have the wasm file which you need to load on the side, which is a bit clunkier. But eh it's a tiny thing

claytongulicktoday at 4:12 PM

It would have been nice if they had mentioned Luke Wagner, who's idea it all was and who created the first implementation, as well as one of the main driving forces behind wasm.

unconedtoday at 2:07 PM

Asm.js was never needed as a legacy mechanism, as it was just a compilation target for native code. There was nothing that it needed to remain backwards compatible with, all asm.js code was new code.

https://acko.net/blog/on-asmjs/

show 1 reply
theultdevtoday at 1:09 PM

Sad day. I have a sha256 hasher in asm.js that's faster than any wasm solution.

show 4 replies
danborn26today at 7:17 PM

[dead]

css_apologisttoday at 1:20 PM

o7

oneshteintoday at 2:19 PM

asm.js is faster than WASM, and it can do everything that JS can do.

show 5 replies