mirror of
https://github.com/servo/servo.git
synced 2026-05-01 07:14:51 +02:00
Page:
Meeting 2015 06 08
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
No results
1
Meeting 2015 06 08
Lars Bergstrom edited this page 2015-06-08 19:41:04 -05:00
Table of Contents
Agenda items
- Friends of the tree (mbrubeck)
- Prepping materials for the training - https://etherpad.mozilla.org/Whistler-Servo-Training (larsberg)
- rust-geom + matrix / generics (gw)
- Cargo target dependencies (jack)
- Interest from AMD in our experiments (larsberg)
- Look into our dependencies again and see if we can break some of them? (gw)
Attending
- larsberg, jack, azita, brson, gw, team samsung, pcwalton, Manish, mbrubeck
Friends of the tree
- mbrubeck: We haven't done them in a while (ever?) on Servo. I wanted to recognize Corey (frewsxcv). He has done a ton of work getting the python code in our build system working. Also work on Travis, Cargo deps, etc. Thanks!
- jack: Yeah, he also added links to the documentation to most of the dependency crates!
- mbrubeck: He knows quite a bit of python, so we might ask him for some reviews on python changes...
- jack: I think I'd like to make him a reviewer for bors, based on jdm's experiences. He's been doing good reviews, so I think we should keep with this plan.
Training
- larsberg: I sent mail to our list about our planned training sessions at Whistler. We've already had a number of signups (including our new acting CTO!). Working on the training material is my focus for the next week or so, and I may ask for help from some of you. There's plenty of interest from the Rust team too.
- azita: Do we (Rust/Servo team) need to sign up too to reserve seats?
- larsberg: We'll see. We're supposed to have room for 60-100 people. I don't think we'll overflow the larger number at least. We can look for more space if needed. Good problem to have.
- jack: Do we need to look for more easy bugs? Will we be relying on those in the training?
- larsberg: Given the number of people we have, I think we should have a number of "fix this w-p-t test" exercises just so they can kick the tires.
- jack: Like, everyone fixes the same bug as an exercise?
- larsberg: Yeah, just to go through the workflow. I haven't written this all up yet though.
- jack: What I did at a previous training, not knowing people's previous experience, is to have some canned exercises, and then for each one a "level 2" version that was more open-ended or harder. So if some people finish early they don't have to just sit around. If it's open-ended enough they can fill up however much time is left until the next thing. It might be nice if we come up with some things in platform or layout. Even if it's artificial.
- larsberg: I was hoping we'd cover one architectural area, have an exercise for that area, then repeat for the next area. We have 3 hours, which isn't an infinite amount of time but we should be able to cover multiple areas.
- gw: I'm pretty sure we can come up with something.
- pcwalton: radial gradients would be easy.
- mbrubeck: How about the :active pseudo-class selector?
- jack: if radial gradients are in azure already, it would let people work through them
- pcwalton: There are layout bugs, but those can be really difficult
- jack: If it was canned and had a test, that woudl be tractible
- azita: How would it go? Do you have an overview first, or do people just dive in?
- larsberg: I'm hoping to do an overview, then one section on each architectural component, with some examples and exercises for each section.
- jack: We should make sure to demo our debugging commands and tools. Stuff like RUST_BACKTRACE, -Z dump-display-list, etc.
rust-geom
- gw: matrix4 is generic over the underlyig datatype. But, it's always f32. Since I have to implement othe roperations, maybe it makes sense to make matrix4 no longer generic? I can't imagine we're going to add anything else. It adds a lot of code complexity with it generic.
- pcwalton: I agree.
- gw: Whenever I've done it in the past, it's always been either on a float or a double, and then it had special SIMD versions anyway.
- pcwalton: Yeah, especially given that we don't have specialization in Rust yet.
- gw: OK, I'll make the matrix4 type concrete on f32. Matrix2 will stay as-is.
- pcwalton: When we SIMD-ify, we may need to do Matrix2, also.
- jack: Make sure to leave a note there. Could also just make anew Matrix4f32 type... but that's verbose. Where does the complexity come from?
- gw: It's in the implementation. It's more complex to read. As I add more types (e.g., Quaternion), it will get even messier.
- jack: Are the matrix types not generic over the units, too?
- gw: They're only Matrix4 over f32 right now.
- mbrubeck: Hard to do matrix math with the units involved. If there's just one scale factor it's OK, but if you're skewing it, how would that work?
Cargo dependencies
- jack: I went through the tree and made everything that is platform-specific such a depdenency. That is bad because, on linux, it's all copied twice. There's no glob/wildcard support for platform targets. This has cleaned up the build so that now we don't build empty OSX packages on Linux. Big thing to watch out for is if you are adding a new architecture (e.g., arm linux), it's super painful because you have to go through the entire dependency tree and put out 10 PRs to repos, some of which aren't owned by us. So, if you're adding new targets, be ready for some pain. If you see weird build problems on strange platforms, you should not be surprised. If you see anything wonky, let me know.
- jack: Also, I'll send an e-mail with numbers, but the target directory sharing is in cargo. A last fix will land in nightly, but the feature will shave at least 25% off of our build time. Also, if you're switching between CEF and a normal Servo build, that will be basically instantaneous. If you build normal debug servo and then cef, it just rebuilds the top servo crate and libembedding. Huge time savings!
- jack: I noticed that a no-op mach build was taking a minute, and that was because there was some O(N^N) algorithm for resolving dependencies, which obviously we'd be the only ones to hit. There's a fix from acrichto that is much better.
AMD
- larsberg: talked to some AMD people at linuxcon and they were very interested in pcwalton's unified memory experiments. They'd love to get some feedback. I'll put pcwalton in touch with them.\
- pcwalton: I'm testing on ARM big.little right now. It's an ODROID octo-core.
- jack: Also, Apple's going all-in on Metal now. It's on OSX and iOS now. Can we make use of this? Overlaps with all the other ones...
- pcwalton: Biggest use cases for Vulkan and Metal are to get control over multithreaded GPU scheduling, which we care about a lot. I'm cautiously optimistic about that. If we upgrade Skia and get Ganesh, and had a layers port to Metal, we might be able to use it and get really nice scheduling on our graphics card usage.
- jack: Bad news is that Apple is all-in on Metal and everybody else is on Vulkan, except for Microsoft who is also on somebody else.
- pcwalton: Yeah, our layers design with multiple backends is probably required to support all of these. Chromium is super OpenGL-heavy, so it will be hard for them to take advantage of these new APIs.
- jack: Does the way our compositor work benefit from this?
- pcwalton: Maybe? We're so simple that it's hard to imagine how we could benefit.
- gw: Biggest thing I see is if we move to GPU painting and can construct efficient GPU command buffers on the paint threads. That woudl be a massive win over where we're at right now.
- pcwalton: Definitely; the way you can use multithreading and the GL API are big wins. Also, multithreaded GL tends to be crashy on drivers. Vulkan is supposed to make drivers a lot simpler to reduce the number of bugs.
- larsberg: that reminds me that I also met somebody at LinuxCon from nvidia who works on the open source drivers who offered to help us out, too.
Dependencies
- gw: We seem to have a really bad dependency chain building up again. If I make a single-line change in rust-layers, it takes 8 minutes to build that. Maybe next quarter we should look at them and see if we can break things up a bit?
- pcwalton: Most important thing is to get script off of the critical path. Only the final build should depende on it.
- gw: Even worse, script depends on the graphics crates because of WebGL.
- jack: Should be able to pull WEbGL out...
- mbrubeck: I was also looking at the rust-layers stuff, and part of it is because util depends on rust-layers and everything dependes on util. This is because of the typed units, which are Pixels in rust-layers, and they're used in util.
- brson: Maybe cargo can detect some of these poor dependency chains?
- pcwalton: I'd rather have incremental compilation in rustc, if that's it.
- gw: Maybe we could use brson's dependency graph in cargo?
- jack: I asked earlier and they said it was out of scope.
- pcwalton: CAn we do it as a plugin?
- larsberg: It is implemented as a custom build command.
- jack: I'll bring this up with edunham. Also, nrc and nmatsakis are looking into compile times right now. It turns out 35% of the time in the script crate is trait resolution. There's a cache, but still a huge percentage of the time. nmataskis has been digging around in that. They're looking at this right now. Hopefully we'll get some easy early fixes to at least make the compile faster.
- pcwalton: I've chatted with nmatsakis for strategies for this in rustc. If it's just where rustc has to check if it's correct, you can go on speculatively to codegen and check simultaneously.
- jack: After doing the cleanup, I also realized we sometimes get out of sync in cargo.lock. Also, get foo from two different crate versions ALL THE TIME. Need a plugin or lint in tidy that checks to ensure we don't have two versions of the same package. We were doing it quite a bit. h5ever gives us two versions of "mac" but it doesn't cause any conflicts yet.