Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/comzyh/TCP-Lab
Stanford cs144 lab,an elegant TCP/IP implementation
https://github.com/comzyh/TCP-Lab
Last synced: 15 days ago
JSON representation
Stanford cs144 lab,an elegant TCP/IP implementation
- Host: GitHub
- URL: https://github.com/comzyh/TCP-Lab
- Owner: comzyh
- Created: 2020-07-04T16:32:10.000Z (over 4 years ago)
- Default Branch: comzyh
- Last Pushed: 2020-09-02T16:55:14.000Z (about 4 years ago)
- Last Synced: 2024-08-01T16:25:33.460Z (3 months ago)
- Language: C++
- Homepage:
- Size: 379 KB
- Stars: 21
- Watchers: 1
- Forks: 24
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
For build prereqs, see [the CS144 VM setup instructions](https://web.stanford.edu/class/cs144/vm_howto).
## Sponge quickstart
To set up your build directory:
$ mkdir -p /build
$ cd /build
$ cmake ..**Note:** all further commands listed below should be run from the `build` dir.
To build:
$ make
You can use the `-j` switch to build in parallel, e.g.,
$ make -j$(nproc)
To test (after building; make sure you've got the [build prereqs](https://web.stanford.edu/class/cs144/vm_howto) installed!)
$ make check
The first time you run `make check`, it will run `sudo` to configure two
[TUN](https://www.kernel.org/doc/Documentation/networking/tuntap.txt) devices for use during
testing.### build options
You can specify a different compiler when you run cmake:
$ CC=clang CXX=clang++ cmake ..
You can also specify `CLANG_TIDY=` or `CLANG_FORMAT=` (see "other useful targets", below).
Sponge's build system supports several different build targets. By default, cmake chooses the `Release`
target, which enables the usual optimizations. The `Debug` target enables debugging and reduces the
level of optimization. To choose the `Debug` target:$ cmake .. -DCMAKE_BUILD_TYPE=Debug
The following targets are supported:
- `Release` - optimizations
- `Debug` - debug symbols and `-Og`
- `RelASan` - release build with [ASan](https://en.wikipedia.org/wiki/AddressSanitizer) and
[UBSan](https://developers.redhat.com/blog/2014/10/16/gcc-undefined-behavior-sanitizer-ubsan/)
- `RelTSan` - release build with
[ThreadSan](https://developer.mozilla.org/en-US/docs/Mozilla/Projects/Thread_Sanitizer)
- `DebugASan` - debug build with ASan and UBSan
- `DebugTSan` - debug build with ThreadSanOf course, you can combine all of the above, e.g.,
$ CLANG_TIDY=clang-tidy-6.0 CXX=clang++-6.0 .. -DCMAKE_BUILD_TYPE=Debug
**Note:** if you want to change `CC`, `CXX`, `CLANG_TIDY`, or `CLANG_FORMAT`, you need to remove
`build/CMakeCache.txt` and re-run cmake. (This isn't necessary for `CMAKE_BUILD_TYPE`.)### other useful targets
To generate documentation (you'll need `doxygen`; output will be in `build/doc/`):
$ make doc
To lint (you'll need `clang-tidy`):
$ make -j$(nproc) tidy
To run cppcheck (you'll need `cppcheck`):
$ make cppcheck
To format (you'll need `clang-format`):
$ make format
To see all available targets,
$ make help