SlideShare a Scribd company logo
WebAssembly overview
• What is WebAsembly
• What it is for?
• WebAssembly Structure
• Tools
• How to use it
• Roadmap
Agenda
• New Standard developed by Mozilla,
Microsoft, Google and Apple
• Compact, portable binary format for web
• Fast to load, runs safely
• Near-native performance
• Works on any device
What is WebAsembly
The Story
• Key person: Brendan Eich
• 1995 – Created JavaScript
• 1995 - Leading SpiderMonkey
• 1998 – Started Mozilla
• 2009 – asm.js Mozilla experiment
• 2013 – asm.js Published
• 2013 – Spread asm.js idea to
Microsoft
• 2014-15 – Make other browser
vendors to join WebAssembly W3C
Group
• Intermediate language
• Subset of Javascript
• C/C++ compiles to asm.js
• Very fast. Best result 1.5x native
• Natively runs in Firefox, Edge, Chrome
asm.js
Web assembly overview by Mikhail Sorokovsky
Web assembly overview by Mikhail Sorokovsky
• Low-Level compiler target
• Less Size
• Less Cold Start
• Readable textual representation
• Convenient Debugger
• Compile-time optimization
• Bytecode instructions ~= CPU instructions
WebAssembly is asm.js Evolution
WebAssembly is
binary AST
• Small set of types
• Basic operations
• Control flows
• Memory
management
• Fill gaps in JavaScript
• Develop using language you like
• Heavy calculation
• Examples:
• P2P applications
• Image / Video / Music editing
• Live video augmentation
• Platform simulation
• CAD application
What it is for?
• Games!!!
• AngryBots
• PlatformerGame
• Examples
Examples
WebAssembly structure
WASM
MODULE A
MODULE B
MODULE C
MODULE D
TYPE IMPORT FUNCTION
TABLE MEMORY EXPORT
START CODE DATA NAME
Operators Example
Operator CPU Description
i32.add addl Sign-agnostic addition
call call Call function directly
i32.load check + mov Load 4 bytes as i32
nop nop No operation
br_if je Conditional break / jump
• All tools are in develop!!!
• Mostly unstable
• Officially 2 ways to built wasm
• wasm binary standard is in development too!!
• Browser might not be able to process wasm in
the moment
TOOLS
BINARYEN
asm2wasm ./fibonacci.asm.js –o fibanacci.wast
wasm-as fibanacci.wast –o fibanacci.wasm
https://github.com/WebAssembly/binaryen
EMSCRIPTEN “incoming” branch
http://kripken.github.io/emscripten-site/
Does not working right now
Try this for your own risk
http://floooh.github.io/fips/index.html
• WebAssembly playground
• ilwasm - .NET CIL => WebAssembly
OTHER
• 15 March 2016 – Experimental support of
WebAssembly
• FirefoxNightly
• Microsoft Edge
• Google Chrome
• Chromium
How To Use
Execution
How To Use WebAssembly
How To Use WebAssembly: dependencies
How To Use WebAssembly: dependencies
Roadmap: MVP ~~~~ THIS YEAR
• Any asm.js => wasm
• Validation
• Execution
• Module
• Text / Binary format
• Cross-browser support
• Polyfill-able in JS
Roadmap: Soon After MVP
• Threads
• Shared Memory
• Dynamic Linking
• Fixed-width SIMD
• Zero-cost exceptions
Roadmap: Future priorities
• Fain-grained memory control
• Large Page Support
• GC/DOM integration
• Memory > 4GiB
• And much more
Conclusions
• Binary Executable format for web
• New Web Standard – part of W3C
• Developed by Key Players on the Web
• Low-level compiler target
• JavaScript brother
• Developed for real computations in browser
Thank You!
Links
• https://wasm.news/
• http://blog.golovin.in/how-to-start-using-
webassembly-today/
• https://callahad.github.io/tccc20-wasm/
• https://github.com/WebAssembly/build-suite
• https://github.com/kripken/emscripten/wiki/Port
ing-Examples-and-Demos

More Related Content

What's hot (20)

PPT
Jenkins Overview
Ahmed M. Gomaa
 
PPTX
Jenkins CI
Viyaan Jhiingade
 
PPTX
Jenkins
MohanRaviRohitth
 
PDF
Introduction to Docker Compose
Ajeet Singh Raina
 
PDF
Docker.소개.30 m
Wonchang Song
 
PDF
Spring Boot
Jaran Flaath
 
PDF
Intro docker
Fedir RYKHTIK
 
ODP
An Introduction To Jenkins
Knoldus Inc.
 
PPTX
Jenkins tutorial for beginners
BugRaptors
 
PDF
Ansible-cours .pdf
Jaouad Assabbour
 
PDF
MongoDB and Node.js
Norberto Leite
 
PPTX
Blazor
Ed Charbeneau
 
PDF
Continuous integration
hugo lu
 
PPTX
Docker Basic to Advance
Paras Jain
 
PPTX
Jenkins Introduction
Pavan Gupta
 
PDF
Paul Angus - CloudStack Backup and Recovery Framework
ShapeBlue
 
PDF
Automation with ansible
Khizer Naeem
 
PDF
Jenkins
Roger Xia
 
PPT
Docker introduction
Phuc Nguyen
 
PPTX
Introduction to docker
Frederik Mogensen
 
Jenkins Overview
Ahmed M. Gomaa
 
Jenkins CI
Viyaan Jhiingade
 
Introduction to Docker Compose
Ajeet Singh Raina
 
Docker.소개.30 m
Wonchang Song
 
Spring Boot
Jaran Flaath
 
Intro docker
Fedir RYKHTIK
 
An Introduction To Jenkins
Knoldus Inc.
 
Jenkins tutorial for beginners
BugRaptors
 
Ansible-cours .pdf
Jaouad Assabbour
 
MongoDB and Node.js
Norberto Leite
 
Continuous integration
hugo lu
 
Docker Basic to Advance
Paras Jain
 
Jenkins Introduction
Pavan Gupta
 
Paul Angus - CloudStack Backup and Recovery Framework
ShapeBlue
 
Automation with ansible
Khizer Naeem
 
Jenkins
Roger Xia
 
Docker introduction
Phuc Nguyen
 
Introduction to docker
Frederik Mogensen
 

Viewers also liked (19)

PDF
WebAssembly
Sergey Rubanov
 
PDF
Is WebAssembly the killer of JavaScript?
Boyan Mihaylov
 
PDF
JavaScript Engine and WebAssembly
Changhwan Yi
 
PPTX
Js engine performance
paullfc
 
PDF
Boyan Mihaylov - Is web assembly the killer of javascript
Codemotion
 
PPTX
The Future of Javascript
Dr Samir A. ROUABHI
 
PDF
Voxxed Days Thessaloniki 2016 - Web assembly : the browser vm we were waiting...
Voxxed Days Thessaloniki
 
PDF
War of Native Speed on Web (SITCON2016)
Min-Yih Hsu
 
ODP
Merre tart az open office.org projekt
Kálmán "KAMI" Szalai
 
ODP
A Firefox-on túl is Mozilla
Kálmán "KAMI" Szalai
 
PPT
Fast Slim Correct: The History and Evolution of JavaScript.
John Dalziel
 
PDF
(COSCUP 2015) A Beginner's Journey to Mozilla SpiderMonkey JS Engine
ZongXian Shen
 
PDF
淺談探索 Linux 系統設計之道
National Cheng Kung University
 
PDF
LLVM 總是打開你的心:從電玩模擬器看編譯器應用實例
National Cheng Kung University
 
PDF
Virtual machine and javascript engine
Duoyi Wu
 
PPTX
Web assembly 맛보기
GyeongSeok Seo
 
PPTX
WTF - Why the Future Is Up to Us - pptx version
Tim O'Reilly
 
PDF
The Future of Everything
Charbel Zeaiter
 
PDF
3 Things Every Sales Team Needs to Be Thinking About in 2017
Drift
 
WebAssembly
Sergey Rubanov
 
Is WebAssembly the killer of JavaScript?
Boyan Mihaylov
 
JavaScript Engine and WebAssembly
Changhwan Yi
 
Js engine performance
paullfc
 
Boyan Mihaylov - Is web assembly the killer of javascript
Codemotion
 
The Future of Javascript
Dr Samir A. ROUABHI
 
Voxxed Days Thessaloniki 2016 - Web assembly : the browser vm we were waiting...
Voxxed Days Thessaloniki
 
War of Native Speed on Web (SITCON2016)
Min-Yih Hsu
 
Merre tart az open office.org projekt
Kálmán "KAMI" Szalai
 
A Firefox-on túl is Mozilla
Kálmán "KAMI" Szalai
 
Fast Slim Correct: The History and Evolution of JavaScript.
John Dalziel
 
(COSCUP 2015) A Beginner's Journey to Mozilla SpiderMonkey JS Engine
ZongXian Shen
 
淺談探索 Linux 系統設計之道
National Cheng Kung University
 
LLVM 總是打開你的心:從電玩模擬器看編譯器應用實例
National Cheng Kung University
 
Virtual machine and javascript engine
Duoyi Wu
 
Web assembly 맛보기
GyeongSeok Seo
 
WTF - Why the Future Is Up to Us - pptx version
Tim O'Reilly
 
The Future of Everything
Charbel Zeaiter
 
3 Things Every Sales Team Needs to Be Thinking About in 2017
Drift
 
Ad

Similar to Web assembly overview by Mikhail Sorokovsky (20)

PPTX
WebAssembly: In a Nutshell
RangHo Lee
 
PPTX
WebAssembly overview. KievJS meetup
Alexandr Skachkov
 
PPTX
Web Assembly Big Picture
Yousif Shalaby
 
PPTX
JS Fest 2018. Александр Скачков. WebAssembly vs JavaScript
JSFestUA
 
PDF
WebAssemlby vs JavaScript
Alexandr Skachkov
 
PDF
Web (dis)assembly
Shakacon
 
PPTX
A Brief introduction to Webassembly
Manuel Eusebio de Paz Carmona
 
PDF
Web assembly brings the web to a new era
Boyan Mihaylov
 
PPTX
Web assembly: a brief overview
Pavlo Iatsiuk
 
PDF
WebAssembly - kolejny buzzword, czy (r)ewolucja?
Brainhub
 
PDF
Assembly thy Web
Martin Ockajak
 
PPTX
Quick overview of WebAssembly
Karl Ritchie
 
PDF
Web Assembly
Valerio Como
 
PDF
Wasm intro
Elifarley Cruz
 
PDF
Altitude San Francisco 2018: WebAssembly Tools & Applications
Fastly
 
PDF
WebAssembly - The Journey (BrazilJS 2017 talk)
Elia Maino
 
PPTX
The Rise of WebAssembly Transforming Web Development for the Modern Era.pptx
SoftflixIT
 
PDF
WebAssembly - czy dzisiaj mi się to przyda do pracy?
Brainhub
 
PPTX
Web assembly with go
WangChow1
 
PDF
WebAssembly. Neither Web Nor Assembly, All Revolutionary
C4Media
 
WebAssembly: In a Nutshell
RangHo Lee
 
WebAssembly overview. KievJS meetup
Alexandr Skachkov
 
Web Assembly Big Picture
Yousif Shalaby
 
JS Fest 2018. Александр Скачков. WebAssembly vs JavaScript
JSFestUA
 
WebAssemlby vs JavaScript
Alexandr Skachkov
 
Web (dis)assembly
Shakacon
 
A Brief introduction to Webassembly
Manuel Eusebio de Paz Carmona
 
Web assembly brings the web to a new era
Boyan Mihaylov
 
Web assembly: a brief overview
Pavlo Iatsiuk
 
WebAssembly - kolejny buzzword, czy (r)ewolucja?
Brainhub
 
Assembly thy Web
Martin Ockajak
 
Quick overview of WebAssembly
Karl Ritchie
 
Web Assembly
Valerio Como
 
Wasm intro
Elifarley Cruz
 
Altitude San Francisco 2018: WebAssembly Tools & Applications
Fastly
 
WebAssembly - The Journey (BrazilJS 2017 talk)
Elia Maino
 
The Rise of WebAssembly Transforming Web Development for the Modern Era.pptx
SoftflixIT
 
WebAssembly - czy dzisiaj mi się to przyda do pracy?
Brainhub
 
Web assembly with go
WangChow1
 
WebAssembly. Neither Web Nor Assembly, All Revolutionary
C4Media
 
Ad

Recently uploaded (20)

PDF
CONCURSO DE POESIA “POETUFAS – PASSOS SUAVES PELO VERSO.pdf
Colégio Santa Teresinha
 
PPTX
HUMAN RESOURCE MANAGEMENT: RECRUITMENT, SELECTION, PLACEMENT, DEPLOYMENT, TRA...
PRADEEP ABOTHU
 
PPTX
CATEGORIES OF NURSING PERSONNEL: HOSPITAL & COLLEGE
PRADEEP ABOTHU
 
PDF
ARAL_Orientation_Day-2-Sessions_ARAL-Readung ARAL-Mathematics ARAL-Sciencev2.pdf
JoelVilloso1
 
PPTX
Identifying elements in the story. Arrange the events in the story
geraldineamahido2
 
PPTX
How to Convert an Opportunity into a Quotation in Odoo 18 CRM
Celine George
 
PDF
Aprendendo Arquitetura Framework Salesforce - Dia 03
Mauricio Alexandre Silva
 
PDF
Geographical Diversity of India 100 Mcq.pdf/ 7th class new ncert /Social/Samy...
Sandeep Swamy
 
PDF
DIGESTION OF CARBOHYDRATES,PROTEINS,LIPIDS
raviralanaresh2
 
PDF
ARAL-Orientation_Morning-Session_Day-11.pdf
JoelVilloso1
 
PDF
QNL June Edition hosted by Pragya the official Quiz Club of the University of...
Pragya - UEM Kolkata Quiz Club
 
PDF
Horarios de distribución de agua en julio
pegazohn1978
 
PDF
Knee Extensor Mechanism Injuries - Orthopedic Radiologic Imaging
Sean M. Fox
 
PPTX
MENINGITIS: NURSING MANAGEMENT, BACTERIAL MENINGITIS, VIRAL MENINGITIS.pptx
PRADEEP ABOTHU
 
PDF
Reconstruct, Restore, Reimagine: New Perspectives on Stoke Newington’s Histor...
History of Stoke Newington
 
PPTX
How to Manage Large Scrollbar in Odoo 18 POS
Celine George
 
PDF
Generative AI: it's STILL not a robot (CIJ Summer 2025)
Paul Bradshaw
 
PDF
The Constitution Review Committee (CRC) has released an updated schedule for ...
nservice241
 
PPTX
Neurodivergent Friendly Schools - Slides from training session
Pooky Knightsmith
 
PPTX
GRADE-3-PPT-EVE-2025-ENG-Q1-LESSON-1.pptx
EveOdrapngimapNarido
 
CONCURSO DE POESIA “POETUFAS – PASSOS SUAVES PELO VERSO.pdf
Colégio Santa Teresinha
 
HUMAN RESOURCE MANAGEMENT: RECRUITMENT, SELECTION, PLACEMENT, DEPLOYMENT, TRA...
PRADEEP ABOTHU
 
CATEGORIES OF NURSING PERSONNEL: HOSPITAL & COLLEGE
PRADEEP ABOTHU
 
ARAL_Orientation_Day-2-Sessions_ARAL-Readung ARAL-Mathematics ARAL-Sciencev2.pdf
JoelVilloso1
 
Identifying elements in the story. Arrange the events in the story
geraldineamahido2
 
How to Convert an Opportunity into a Quotation in Odoo 18 CRM
Celine George
 
Aprendendo Arquitetura Framework Salesforce - Dia 03
Mauricio Alexandre Silva
 
Geographical Diversity of India 100 Mcq.pdf/ 7th class new ncert /Social/Samy...
Sandeep Swamy
 
DIGESTION OF CARBOHYDRATES,PROTEINS,LIPIDS
raviralanaresh2
 
ARAL-Orientation_Morning-Session_Day-11.pdf
JoelVilloso1
 
QNL June Edition hosted by Pragya the official Quiz Club of the University of...
Pragya - UEM Kolkata Quiz Club
 
Horarios de distribución de agua en julio
pegazohn1978
 
Knee Extensor Mechanism Injuries - Orthopedic Radiologic Imaging
Sean M. Fox
 
MENINGITIS: NURSING MANAGEMENT, BACTERIAL MENINGITIS, VIRAL MENINGITIS.pptx
PRADEEP ABOTHU
 
Reconstruct, Restore, Reimagine: New Perspectives on Stoke Newington’s Histor...
History of Stoke Newington
 
How to Manage Large Scrollbar in Odoo 18 POS
Celine George
 
Generative AI: it's STILL not a robot (CIJ Summer 2025)
Paul Bradshaw
 
The Constitution Review Committee (CRC) has released an updated schedule for ...
nservice241
 
Neurodivergent Friendly Schools - Slides from training session
Pooky Knightsmith
 
GRADE-3-PPT-EVE-2025-ENG-Q1-LESSON-1.pptx
EveOdrapngimapNarido
 

Web assembly overview by Mikhail Sorokovsky