mirror of
https://github.com/servo/servo
synced 2026-04-25 17:15:48 +02:00
Page:
Meeting 2013 08 05
Pages
Adding a new WebIDL binding
Alternative Logo Proposals and Related Swag
Asynchronous WebAssembly compilation project
Austin Oxidation
Autogeneration of style structs
Basic SVG support project
Beginner's guide to rebasing and squashing
Benchmarking
Benchmarks
Bots
Browser Engine Research
Build Errors FAQ
Buildbot administration
Building for Android
Building for Magic Leap
Building for UWP
Building on ARM desktop Linux
Building
CI Services we use
CSS parse error reporting
CSSOM student project
Canvas rendering project
Cargo upgrade service project
Code rust concurrency
Code Review
Code of Conduct
Coding standards
Compiler upgrade recipes
Compositor Layer Design
Contributing
Control Servo using WebDriver
Creating and viewing WARC web archives in Servo
Creating new OpenSSL Windows binary distributions
Cross compiling from linux to mac
Crowbot
Css selector matching meeting 2013 07 19
DOM Design
DOM documentation
DOM missing pieces
Debugging JS web compat issues
Debugging and editing tools
Debugging
Design
Developer tools student project
Devtools CSS errors
Devtools plans
Devtools
Diagnosing SpiderMonkey JIT issues
Eric Atkinson visit 2013 09 10
Events and sundry
Expand HTTP request response monitoring
Fetch improvement project
Firefox Reality release notes
FirefoxReality build
Firewall setup for servo master1
Focus student project
Form validation student project
GSoC project brainstorming
Garbage collected DOM
Getting started with layout
GitHub Labels
Github & Critic PR handling 101
Github workflow
Glossary
Governance
Graphics toolkit integration
HTML parser improvement project
HTMLElement binding conversion
HTTP archive support project
HTTP library requirements
Hawaii Rooting
High priority content for layout
Highfive
HoloLens 2 test plan
Home
How to generate GStreamer binaries for CI
Image load conformance student project
Image maps project
Implement HTML charset parsing project
Implement ImageBitmap project
Implement missing WebAudio automation student project
Implement support for missing XMLHttpRequest APIs
Implement worker modules
Implementing a web standard (RGSoC)
Improve specification conformance of unicode bidi library
Incremental flow tree construction
Infrastructure
Integrate xml5ever
Intern project brainstorming
Intern projects
JS objects, wrappers, and cross origin concerns 2013 08 07
Layout 2020
Layout Overview
Layout resources
Layout revamp ideas
Leo meyerovich visit 2013 07 22
Linux sandboxing
London Oxidation
London Security
Meeting 2014 10 27
Meeting 2014 12 08
Meeting 2012 02 08
Meeting 2012 02 16
Meeting 2012 07 20
Meeting 2013 04 01
Meeting 2013 04 15
Meeting 2013 04 22
Meeting 2013 04 29
Meeting 2013 05 06
Meeting 2013 05 13
Meeting 2013 05 20
Meeting 2013 06 03
Meeting 2013 06 10
Meeting 2013 06 14
Meeting 2013 06 17
Meeting 2013 06 24
Meeting 2013 07 01
Meeting 2013 07 15
Meeting 2013 07 22
Meeting 2013 07 29
Meeting 2013 08 05
Meeting 2013 08 12
Meeting 2013 08 19
Meeting 2013 09 09
Meeting 2013 09 16
Meeting 2013 09 23
Meeting 2013 09 30
Meeting 2013 10 14
Meeting 2013 10 21
Meeting 2013 10 28
Meeting 2013 11 04
Meeting 2013 11 18
Meeting 2013 11 25
Meeting 2013 12 02
Meeting 2013 12 09
Meeting 2013 12 16
Meeting 2014 01 06
Meeting 2014 01 13
Meeting 2014 01 21
Meeting 2014 01 27
Meeting 2014 02 03
Meeting 2014 02 10
Meeting 2014 02 24
Meeting 2014 03 10
Meeting 2014 03 17
Meeting 2014 03 24
Meeting 2014 03 31
Meeting 2014 04 07
Meeting 2014 04 14
Meeting 2014 04 21
Meeting 2014 04 28
Meeting 2014 05 05
Meeting 2014 05 13
Meeting 2014 05 19
Meeting 2014 06 09
Meeting 2014 06 17
Meeting 2014 06 23
Meeting 2014 06 30
Meeting 2014 07 07
Meeting 2014 07 14
Meeting 2014 07 21
Meeting 2014 07 29
Meeting 2014 08 04
Meeting 2014 08 11
Meeting 2014 08 12
Meeting 2014 08 18
Meeting 2014 08 25
Meeting 2014 09 08
Meeting 2014 09 15
Meeting 2014 09 22
Meeting 2014 09 29
Meeting 2014 10 06
Meeting 2014 10 13
Meeting 2014 10 20
Meeting 2014 11 10
Meeting 2014 11 17
Meeting 2014 11 24
Meeting 2014 12 15
Meeting 2015 01 05
Meeting 2015 01 12
Meeting 2015 01 26
Meeting 2015 02 09
Meeting 2015 02 23
Meeting 2015 03 02
Meeting 2015 03 16
Meeting 2015 03 30
Meeting 2015 04 06
Meeting 2015 04 13
Meeting 2015 04 27
Meeting 2015 05 04
Meeting 2015 05 11
Meeting 2015 05 18
Meeting 2015 06 01
Meeting 2015 06 08
Meeting 2015 06 15
Meeting 2015 07 06
Meeting 2015 07 13
Meeting 2015 07 27
Meeting 2015 08 10
Meeting 2015 08 17
Meeting 2015 08 24
Meeting 2015 08 31
Meeting 2015 09 14
Meeting 2015 09 21
Meeting 2015 09 28
Meeting 2015 10 05
Meeting 2015 10 12
Meeting 2015 10 19
Meeting 2015 10 26
Meeting 2015 11 02
Meeting 2015 11 09
Meeting 2015 11 16
Meeting 2015 11 30
Meeting 2016 01 04
Meeting 2016 01 11
Meeting 2016 01 25
Meeting 2016 02 01
Meeting 2016 02 08
Meeting 2016 02 22
Meeting 2016 03 07
Meeting 2016 03 21
Meeting Devtools Servo 2
Meetings
Microdata project
Minutes Hackathon 2012 03 27
Missing DOM features project
More ServiceWorker support project
More developer tools student project
Mozlandia Automation
Mozlandia B2S
Mozlandia JS
Mozlandia Rust In Gecko
Mozlandia WPT
Mozlandia gfx
Mozlando Devtools Servo
Mozlando Oxidation
Mozlando SM Servo
Mozlando Servo Bluetooth
Mozlando Servo MagicDOM
Mozlando Servo SMStrings
Mutation observer project
Mutation testing project
NCSU student projects
Network security project
Off main thread HTML parsing project
Offscreen canvas improvements project
Offscreen canvas project
Orlando Oxidation 2018
Oxidation 2015 11 05
Persistent sessions student project
Preparing ARM libraries for CI
Priority of CSS properties
Priority of DOM implementation
Priority of dom bindings
Private browsing student project
Profiling
Project proposal deadlines
Prototype JS form controls student project
Prototype ways of splitting the script crate
Publishing a new ANGLE NuGet version
Publishing a new app store release
Push vs Pull for caching
Random web content project
Refactor GLES2 student project
Refactor bluetooth support student project
Remaining work
Removing push notifications from IRC hooks
Replace C libraries student project
Report new contributors project
Representation of computed style
Research
Reviewer
Roadmap
Running Web Platform Tests on Servo
Rust HTML parser
Rust SpiderMonkey debugger API
Rust cssparser code walk 2013 08 02
SaltStack Administration
San Francisco Oxidation
Servo Benchmarking Report (December 2024)
Servo Benchmarking Report (November 2024)
Servo Benchmarking Report (October 2024)
Servo Layout Engines Report
Servo and SpiderMonkey Report
Servo for Gecko Developers
Specification Links
SpiderMonkey related tasks
SpiderMonkey infodump
SpiderMonkey upgrade details
Storage student project
Streaming webassembly student project
Strings
Student project brainstorm
Student projects
Styling overview
Stylo hacking guide
Summer of Code 2014: Implement XMLHttpRequest
Summer of Code 2016: Fetch API
Summer of Code 2016: File support
Summer of Code 2016: ServiceWorker infrastructure
Summer of Code projects
Summit meeting 2013 09 09
Support WebDriver based tests project
Syncing web platform tests (WPT)
TaskCluster
Testing
Tools
Tracking intermittent failures over time project
Transcription Notes from Servo Architecture talk in Suwon
Transcription notes from rust patterns talk in suwon
Transcription parallelism
Transcription rust concurrency
Transcription rust runtime
Transription layout and acid2
Trinity College Dublin student projects
UPenn student projects
Updating the Rust compiler used by Servo
Upgrading non taskcluster linux CI machines
Upgrading the UWP gstreamer binaries
Upgrading the windows LLVM binaries
Upgrading wptrunner
Using DOM types
Using Rust Spidermonkey Prototype
Using WebWorker Prototype
Version 0.1
Videos and presentations
WebAudio JS interfaces student project
WebAudio nodes student project
WebCompatBug
WebSocket student project
Webdriver student project
Webdriver tests student project
Webrender Overview
Whistler 2019 notes
Whistler Bugzilla
Whistler FFOS
Whistler GFX
Whistler Houdini1
Whistler Houdini2
Whistler Necko
Whistler Oxidation 2019
Work items for new contributors
Workweek COW DOM
Workweek alt js
Workweek android arm
Workweek boot 2 servo
Workweek compiler lints
Workweek displaylist
Workweek dogfooding
Workweek encoding
Workweek generated content
Workweek governance
Workweek graphics stack
Workweek graphics toolkit
Workweek incremental layout
Workweek js bindings status
Workweek layers
Workweek layers2
Workweek pixels
Workweek rasterization
Workweek reftests
Workweek roadmap
Workweek script crate
Workweek security
Workweek string interning
Workweek tables
Workweek writing modes
XML parser student project
infra triage notes
jQuery status
webxr.today support
Clone
1
Meeting 2013 08 05
Josh Matthews edited this page 2013-08-05 18:00:09 -07:00
Servo Meeting 2013-08-05
Agenda
- quadtree memory issues
- request for help on binding conversion
- landing parallel layout work
- 0.1 release criteria
- benchmarks
- acid1
Attending
- kmc, jdm, jack, seo, ryan, dherman, eatkinson, tikue, eschweic, brson, pcwalton
quadtree tile memory issues
- jack: samsung brought this up and we were wondering how it's supposed to work
- eston: for the most part tiles are being deleted correctly when i use it, monitoring with the opengl profiler. what i do to delete tiles is a method that checks if they are far away from the tile that was just added. it's not the best heuristic in the world. there weren't very many details about how they were checking. the other issue is that it does save tiles until a certain memory limit. so maybe that limit is never getting reached.
- jack; do you know what the memory limit is?
- eston: i'm not sure what hte units are, but it is 1M pixels or 10M pixels i think.
- jack: ryan, seo, do you have a test page you were observing this with or know what the memory usage was?
- seo: memory increase happens on any page. like when you zoom in and zoom out
- jack: eston: we don't evict until we hit hte limit, correct?
- eston: when you zoom back out the tiles will still be there so we can just rerender them.
- seo: we'll summarize our findings and send an email
binding conversion help
- jdm: i have a PR open right now that starts converting text nodes and a few html elemnts to use generated bindings. the last commit (converting <a> (HTMLAnchorElement)) shows what other elements will require. it's a good model and it's really easy to break up into one element at a time, so it can be easily parallelized. i would like people to start helping because there are a lot of elements. i copied the idl files from moz-central (dom/webidl).
- jack: it would probably be nice for each of us to do some. this is the stuff like DListElement right?
- jdm: yes
landing parallel layout
- pcwalton: i'd rather have correct layout than fast layout. we had problems in the past where intern code didn't last long. if we integrate early it should be better.
- jack: what about the flag, why is the flag needed?
- pcwalton: i'm worried that it will be too slow.
- eatkinson: you probably won't notice the speed because CSS selector matching takes so long
- brson: we have two options, even thought it's parallel code can we still do it sequentially?
- pcwalton: even if we knew we were going to ship parallel layout we need a control feature to compare against.
- brson: i feel like we want to preserve this flexibility
- eatkinson: ok, i'll try and get it landed this week.
system libraries for android
- samsung: currently servo is relying on some system libraires like freeytpe and fontconfig. we'd like to wrap that in a servo
- jack: i have no objection
- pcwalton: what does webkit on android use?
- seo: we considered two laternatives, including binary form somewehre, the second way is to include the source in the repo.
- pcwalton: it may be that android doesn't need fontconfig
- brson: it may be that hte NDK toolchain doesn't have the freetype headers
- jdm points to http://en.wikibooks.org/wiki/OpenGL_Programming/Installation/Android#FreeType - "If you need FreeType (a library to render fonts), you'll need to cross-compile it. Note: The Android system uses FreeType but internally it doesn't expose it to native apps."
- samsung: we'll let you know the address of our repo. please take a look.
- jack: so it sounds like everybody has to cross-compile freetype. we're already bundling several libraries so building some more. i'm happy if you add more submodules for freetype and fontconfig, and we'll linke those into the build system.
0.1 criteria
- jack: sent out mail last week: https://groups.google.com/forum/#!topic/mozilla.dev.servo/4yPk-veDr7U
- kmc: wrt security, should we think about replacing stb-image before claiming it to be usable?
- pcwalton: there are many libraries required to replace it with. libpng, libjpegturbo.
- kmc: not trivial but I'd rather 0.1 only supports a few but is theoretically secure instead of supporting lots and being known secure
- pcwalton: how much is security a milestone?
- jdm: also using a year-old spidermonkey
- pcwalton: don't think anybody will be using servo
- kmc: matter of principle. part of the point is for servo to be secure
- pcwalton: when do we focus on security, add sandboxing, etc?
- kmc: can't claim to be secure as long as we have all this unsafe code, segfaults, etc.
- pcwalton: concerned about segfaults
- jack: DLBI added, agreement that embedding important, android important. anything else? what about benchmarks?
- sanxyin: should use netsurfcss in 0.1?
- pcwalton: not happy with it but wouldn't block
- brson: agree. it's functionally complete
- brson: will give a bad impression about perf
- jack: 0.2 will have a huge jump in perf though
- kmc: major thing there is selector matching?
- jack: that is like all the work though
- kmc: perf is so bad that we don't need parallel matching?
- pcwalton: yes
- kmc: do we need stack switching on 64-bit?
- pcwalton: no. patches are not in yet
- jack: not going to block on netsurfcss
- jack: back to benchmarks... purpose would be to get a baseline from which to show improvements
- pcwalton: that's why we need dlbi. otherwise numbers will be bad
- jack: things we're interested in: memory use (important for mobile) - calculating memory after layout would be good.
- jack: posted a message from blink-dev about cpu use in different areas on the main thread. might be nice to come up with similar test.
- brson: do we need some sort of automated dashboard, isservofastyet, so we can start capturing these over time?
- jdm: could we reuse the same things used for rust?
- brson: I think that's just matplotlib.
- pcwalton: it would be nice to use the profiler, but it's not event-based. it would be better to do something based on events like page loaded, restyled, etc. instead of time.
- jack: we could have the profiler spit out a json file as well as an image after page load.
- ... notes missing ...
- jack: do we want any other projects? jdm's dom wrapper work? (something else)
- brson: no, we don't need to be too ambitious. is there any kind of automation?
- jack: there's some kind of make target?
- brson: let's make sure it's hands-off, we're not really focused on releases.
Benchmarks
- jack: got feedback privately from brendan to focus on parallelism rather than single-threaded cases
- jack: for general cases of dom manipulation, layout, selector matching, we should probably focus on ...
- jack: when in portland, talked about jdm's testcase of setting style property and calling getclientrect in a tight loop (microbenchmark). pushback saying we should look at macrobenchmarks instead. went looking for benchmarks, most seem to focus on JS performance disappointingly.
- brson: we've talked about instagram (?). cross-origin iframes.
- pcwalton: servo won't win on image decoding. stb-image is slow.
- jack: imaging synthetic benchmark: iframes doing work (calculating 1000th fib number in stupid way)
- pcwalton: we should win on that.
- jack: don't want to create stuff that's stupid, but it seems like w'ell need to create our own benchmarks and want to stimulate thought about what those should look like.
- jack: resizing with lots of iframes should be a good one, since all iframes should reflow in parallel unlike other browsers. we'd also like to not totally suck if there's one iframe vs several hundred.
- jack: seems like we should have benchmarks for selector matching too.
- pcwalton: I'd like to see a general page like wikipedia; timeline of where we are relative to gecko and webkit, don't have infra to do that. that's where we'll see meaningful data - what to work on, what to do to close the gap.
- jack: run single vs. parallel layout on 100 wikipedia pages?
- pcwalton: dom microbenchmarks ...
- jack: what infra do we need?
- pcwalton: take existing profiling stuff, make timeline view. event monitoring... timeline view like in firefox and chrome devtools.
- jack: no way to profile across function calls right now, since it takes callback.
- pcwalton: take existing profiler, augment so instead print out a log of time T event E. write script to turn that into timeline display, then can compare to gecko.
- jack: ok, sounds good.
Acid 1
- jack: we're close. all boxes showing, bottom ones too low.
- samsung: doesn't that need margin-collapse?
- jack: maybe. that might be the issue we're seeing.
- jack: trhee problems: borders on bar maid not there - asymmetric borders. boxes too far down, and paragraph not reading inline style. then radio button, too.
- pcwalton: don't need form widgets to pass.
- jack: bang and whimper shouldn't be on top of each other. small things, looking good.
- eatkinson: I don't think those borders should collapse.
- jack: we have clear now; not necessary for acid1 but still awesome.
- samsung: floating elements should be painted over background, but currently painted behind. building display list should happen in stages.
- pcwalton: no, should be a way to place items at different positions in display list. multiple traversals slower, but we can place items in list and string them together.
- eatkinson: things lower in tree go on top (not always true with floats)
- samsung: currently in tree order, but not true for floating elements.
- jack: seo, can you file a bug?
- seo: sure.