| Commit message (Collapse) | Author | Age |
... | |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
There was previously a huge amount of shared code that had to be
copied back and forth. This should reduce the maintenance burden
by containing all future changes to a single file.
New unified library is fully backwards-compatible but also
introduces and the easy-to-use `for_each_job` macro which
replaces the specific `for(...) START_LOOP ... STOP_LOOP`
format requirement and is generally much harder to abuse.
New unified library also automatically cleans up its shared memory
and semaphores, so this commit also removes the separate
`cleanupSemaphores` binary.
I also found a precursor of `extra.h` written by Sims in
`litmusStuff.h`. This code is only interesting for historical
purposes, so it is also removed in this commit.
This commit also adds debug options to all the Makefiles and
silences rm's complaints about non-existent files in make clean.
|
|
|
|
|
| |
New macro `for_each_job` simplifies instrumentation.
Backwards-compatible.
|
|
|
|
|
| |
Everything without isolation: run_tacle_rtss20.sh
For isolation you have to run the hodgepodge of scripts as before.
|
|
|
|
|
|
|
|
|
| |
DANGER! There's an inconsistency in the input files used for the
all-pairs tests and those used for the baseline tests.
Baselines: run_all_dis.sh calls run_dis.sh to do all baselines.
All-pairs: Uses old TACLe script (not included here).
Cache allocation 2nd-order effects on SMT friendliness: run_pair_convexity.sh
|
|
|
|
|
| |
Also fixes a missing header in DISstressmarkRNG.h and the "all"
make target. No functional changes.
|
|
|
|
|
| |
These are compatible with the outputs of all the DIS stressmarks
as instumented with `extra.h`.
|
|
|
|
| |
Also remove some unused code from the cleanupSemaphores utility
|
|
|
|
| |
Now as used for (rejected) RTSS'20 paper
|
|
|
|
|
|
|
|
|
|
|
| |
- All: Output times to stderr and nothing to stdout
- Field, Update, Pointer: change definition of a job to match other
stressmark execution times more closely
- Matrix: move all allocations into main()
- Update: Use volatile to prevent computations from being optimized out
- Transitive: Use volatile to prevent computations from being optimized out
- Neighborhood: Use working version of drawLineSegment from original DIS
sample code
|
|
|
|
|
|
|
|
|
|
|
| |
- No parameter or output format changes
- Better error messages
- Auto-detect core
- Fix off-by-one error in job counting
- Explicitly invoke the scheduler with sched_yield() between jobs
so that there's less work to do when (if) the scheduling timer
interrupt comes around. (This has a surprisingly significant
impact on timings.)
|
|
|
|
|
| |
Note that this repo does not attempt to keep a copy of the original
DIS benchmark distributions. UNC real-time has another repo for that.
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Changes:
- Backpoint fix to randInt range
- Instrument benchmarks with time tracking
- assert inputs are correct length to fix compiler warnings
Problems:
- Timing on a per-loop basis is non representative of real-world
workloads, as we clear the cache after every loop. These all need
to be re-instrumented to record times for the whole benchmark,
rather than per-loop.
|
| |
|
|
|
|
|
|
| |
- Use malloc rather than static allocations
- Check that timings array is long enough before inserting each sample
- Include clearer error handling
|
| |
|
| |
|
|
|
|
| |
Works for three-way WSS/cache size/execution time comparisons
|
|
|
|
| |
A heavily rewritten version of mc2spin as written by Namhoon.
|
| |
|
|
|
|
|
|
|
| |
- Revert type change in Neighborhood microbenchmark
- Remove inputs modified to fix in the available memory on the
i.MX6DQ PRP test platform
- Change default configuration to build without LITMUS/MC^2/MMDC
|
|
|
|
|
| |
***This is the final commit which supports reproducing his
PRP results***
|
|
|
|
| |
Note that Neighborhood has been modified to use less space
|
| |
|
|
|
|
|
|
|
|
| |
- Remove unused parameters to extra.h
- Use floats to avoid integer overflow when timing long loops
- Only include litmus headers and/or MMDC headers if the appropriate
define is set in extra.h
- Update job parameters to match those used in my PRP experiments
|
| |
|
| |
|
| |
|
| |
|
|
|