[tor-project] Sponsor 38 update (Shadow simulator)

Jim Newsome jnewsome at torproject.org
Mon Jun 1 18:59:27 UTC 2020


Sponsor 38:
https://trac.torproject.org/projects/tor/wiki/org/sponsors/Sponsor38

We've been primarily focused on prototyping the new process-based
simulation architecture https://github.com/shadow/shadow/milestone/16:

-   General libc + syscall interposition plumbing is fairly stable now,
    including marshaling pointer arguments across the Shadow/Plugin
    process boundary, in both the ptrace and the LD_PRELOAD
    interposition mechanisms.

-   Settled on a logging design and implemented it. In particular we
    needed to address the problem of logging from our "shim" code that's
    LD_PRELOADed into the plugin's process. Since it's no longer in
    Shadow's process, we can't directly use Shadow's logger, which
    references internal Shadow data structures and in-memory queues. To
    further complicate things, some code runs both inside Shadow and
    inside the LD_PRELOADed library, and that code should use Shadow's
    logger when and only when running inside Shadow. We developed a
    simple plugabble logger that writes to stdout by default, uses
    Shadow's logging when running inside Shadow, and a "shim logger"
    when running inside the LD_PRELOADed shim. This also allows us to
    use the same logging API inside tests and support libraries.

-   We've gotten more syscalls and parts of libc implemented, including
    syscalls from unistd.h and most of the socket.h syscalls. These are
    the basic interfaces used by almost every network program to handle
    communication and file descriptor i/o. We are nearly ready to start
    running some multi-process networking benchmarks.

We've also made some general improvements on the public Shadow branch
https://github.com/shadow/shadow/pulls?page=2&q=is%3Apr+is%3Aclosed+updated%3A%3E%3D2020-03-19:

-   Added both debug and release builds to our continuous integration
    test matrix, helping us catch more bugs before they get merged.

-   Got rid of the monolithic shadow.h header, substantially speeding up
    incremental builds, and improving compatibility with code analysis
    tools.

-   Documentation cleanup and additions, including adding contributor
    guidelines.

-   Reduced flakiness in multi-process networking tests by moving away
    from hard-coded server ports.

-   Added additional integration tests to cover functionality being
    implemented in the new process-based model.

-   Migrated from Python 2 to 3.

We also spent some time strategizing about how to use Github
"milestones" and "issues" to help us plan and prioritize development
work and to keep the community updated on our progress. We are still in
the early stages and hope to make more effective use of these planning
tools over time.

Finally, we're thrilled to welcome Steve Engler to the project. Steve is
starting today: Monday, June 1.


More information about the tor-project mailing list