github ColinIanKing/stress-ng V0.18.12

5 days ago

stress-ng V0.18.12 "manic memory mangler"

New stressors

  • easy-opcode - simple easy opcode stressor for stressing front end decoder and instruction cache
  • physmmap - physical memory mapping (/dev/mem) stressor
  • umask - umask system call exercising stressor

New options

  • --vmstat-units - vmstat memory scaling option
  • --aggressive - aggressive mode now works on more stressors
  • --minimize - size minimization mode now works on more stressors
  • --maximize - size maximization mode now works on more stressors

Detailed Changelog

[Dmitry Antipov]physmmap: add physical memory mapping (/dev/mem) stressor

  • stress-link/memfd/mmaphuge/mmaptorture: fix global buffer overflow

[Dmitry Grand]

  • fix error: assignment to ‘void (* const*)(stress_fma_t *)’

[Nicolas Bouton]

  • stress-prefetch: add aarch64 load prefetch instructions (prfm)

[Sergey Fedorov]

  • Enable PPC32 builds, use PPC32 opcodes

[Zong Li]

  • core-asm-ret: add lpad instruction in return code on RISC-V

[Colin Ian King]

  • debian/control: update standards version to 4.7.2
  • stress-easycopy: ensure direction flag is cleared
  • core-asm-ret: add PPC64 big endian and PPC little and big endian support
  • stress-flushcache: call dcbst_page for PPC and PPC64
  • stress: improve checking for ppc and ppc64
  • README.md: update contributor list
  • stress-nop: make policy non-clobberable for ppc32 gcc 4.9.2 builds
  • stress-cyclic: make policy non-clobberable for ppc32 gcc 4.9.2 builds
  • README.md: add another research paper link
  • stress-hyperbolic: long double trig should be at least as accurate as double
  • stress-trig: long double trig should be at least as accurate as double
  • stress-opcode: Fix incorrect opcode mmap size, 2 pages short
  • stress-lockbus: add timer to break out stuck split locks on ppc64
  • stress-regex: Fix digits regex name, should be digits and not alphas
  • stress-physmmap: Fix spelling mistake "mappping" -> "mapping"
  • core-shim: fix spelling mistake "obsolute" -> "obsolete"
  • stress-tlb-shootdown: page align two more offsets
  • stress-tlb-shootdown: msync memfd mapping using the correct size
  • stress-malloc: only declare tmp_align for aligned allocations
  • stress-tlb-shootdown: page align offsets
  • stress-opcode: fix void * pointer arithmetic, use uint8_t *
  • stress-easy-opcode: fix void * pointer arithmetic, use uint8_t *
  • stress-misaligned: perform __uint128_t access using uint64_t pointers
  • stress-open: always unlink file on O_TRUNC open
  • stress-stream: add hex string compare of checksums
  • stress-stream: fix checksum string termination, should be using index j
  • Manual: Fix spelling mistake "execises" -> "exercises"
  • stress-physmmap: add upper region size bounds check
  • stress-easy-opcode: ensure enough end spaces is available for return ops(s)
  • core-arch.h: move endian macros to core-arch.h
  • stress-easy-opcode: fix ppc64 build, replace . with ,
  • stress-opcode: clean up object code size handling
  • stress-easy-opcode: add a simple easy opcode stressor
  • stress-tlb-shootdown: make TLB shootdowns more aggressive, add metrics
  • core-cpu-cache: only use clflushopt if it is supported by the processor
  • stress-cpu: disable FP denormalization to improve performance
  • core-cpu: add helpers to disable/enable fp denormalization
  • kernel-coverage: add --physmmap-read test
  • stress-physmmap: use VERIFY_NONE since there are no verifications
  • core-cpu-cache: fix build issue, use renamed variable
  • stress-physmmap: add --physmmap-read option to force read data in every page
  • stress-misaligned: use atomic_fetch_add if 2,4,8 byte variants unavailable
  • core-cpu-cache: use uint8_t for pointers to avoid void * pointer arithmetic
  • stress-cache: prefetch data closer to the CPU
  • stress-physmmap: attempt to mmap entire region in one mmap
  • stress-physmmap: make mappable_pages a register size_t
  • stress-physmmap: report if no pages were mappable
  • stress-physmmap: add physical memory mapping (/dev/mem) stressor
  • README.md: Add Nicolas Bouton to contributors list
  • Makefile: add sanitization build flags
  • README.md: Add Zong Li to contributors list
  • Remove stress-mpfr.
  • core-parse-opts: rename scales to type of scaling
  • stress-uprobe: cast size_t to ssize_t for sane type comparison
  • stress-uprobe: prevent buffer overflows when parsing data
  • stress-race-sched: fix off-by-one comparison on method_all_index
  • stress-malloc: ensured aligned_alloc is a multiple of alignment
  • README.md: Add Dmitry Antipov and Dmitry Grand to contributors list
  • README.md add another research citation
  • README.md: add some more kernel bug references
  • stress-shellsort: use mmap data, collapse pages to try to sort on hugepage mapped data
  • stress-insertionsort: use mmap data, collapse pages to try to sort on hugepage mapped data
  • stress-heapsort: used mmap data, collapse pages to try to sort on hugepage mapped data
  • stress-bubblesort: used mmap data, collapse pages to try to sort on hugepage mapped data
  • stress-bitononicsort: fix mmap'd anon mapped name
  • stress-bitonicsort: used mmap data, collapse pages to try to sort on hugepage mapped data
  • stress-qsort: collapse pages to try to sort on hugepage mapped data
  • stress-mergesort: collapse pages to try to sort on hugepage mapped data
  • stress-workload: force no hugepages on mapping for more PTEs
  • stress-numa: force no hugepages on mapping for more PTEs
  • stress-memthrash: force no hugepages on mapping for more PTEs
  • core-madvise: add stress_madvise_nohugepage, clean up madvise helpers
  • core-madvise: move stress_madvise_collapse from core-helper to core-madvise
  • stress-vm: add collapse to vm-madvise options for MADV_COLLAPSE
  • stress-matrix-3d: improve performance by using MADV_COLLAPSE
  • stress-matrix: improve performance by using MADV_COLLAPSE
  • stress-memrate: improve performance by using MADV_COLLAPSE
  • core-heler: add stress_madvise_collapse to collapse pages to hugepages
  • README.md: update number of stressors and stressor types
  • stress-umask: add umask system call exercising stressor
  • stress-mmaptorture: add MADV_RANDOM on zero sized allocation
  • README.md: add a couple more research paper links
  • core-shim: add build-time check for close_range, use it in core-shim
  • stress-prefetch: perform uint64_t pointer addition correctly
  • core-helper: check for pipe on stdin and sort out tty width accordingly
  • README.md: add another research paper link
  • matrix-methods.job: remove hot from hot-cpu
  • core-cpu-cache: add #elif for cacheflush, helps static analyzer
  • stress-bigheap: use bit-wise & for logical anding
  • stress-numa: use bit-wise & for logical anding
  • stress-zombie: voidify return from shim_usleep()
  • stress-zlib: maximize/minimize --zlib-level, --zlib-mem-level
  • stress-yield: maximize/minimize --yield-procs
  • stress-swap: enable --swap-self on --aggressive
  • stress-stack: enable --stack-{fill|mlock|pageout|swap} on --aggressive
  • stress-sock: maximize/minimize --sock-msgs
  • stress-shm-sysv: enable --shm-sysv-mlock on --aggressive
  • stress-shm: enable --shm-mlock on --aggressive
  • Manual: fix missing sysv shared memory heading
  • stress-sem: enable --sem-shared on --aggressive
  • stress-resources: enable --resources-mlock on --aggressive
  • stress-remap: minimize --remap-pages
  • stress-readahead: limit --readahead-bytes maximized setting to MAX_32
  • stress-randlist: maximize/minimize --randlist-items, --randlist-size
  • stress-ramfs: fix minimize option, bump max ramfs size to 2GB
  • stress-ramfs: make --ramfs-fill fill pages with random data
  • stress-ng: check for stressors that should be ignore
  • stress-ramfs: maximize/minimize --ramfs-size
  • stress-pty: maximize/minimize --pty-max
  • stress-pseek: maximize/minimize --pseek-io-size
  • stress-pseek: enable --pseek-rand on --aggressive
  • stress-poll: maximize/minimize --poll-fds
  • stress-pipeherd: enable --pipeherd-yield on --aggressive
  • stress-pipe: maximize/minimize --pipe-data-size, --pipe-size
  • Manual: fix indentation on --pci-ops-rate option
  • stress-pagemove: enable --pagemove-mlock and --pagemove-numa on --aggressive
  • stress-open: minimize --open-max
  • stress-numa: enable numa-shuffle-addr and numa-shuffle-node on --aggressive
  • stress-numa: maximize/minimize --numa-bytes
  • Manual: fix missing netlink task title
  • stress-nanosleep: maximize/minimize --nanosleep-threads
  • stress-msg: maximize/minimize --msg-bytes
  • stress-mpfr: maximize/minimize --mpfr-precision
  • stress-monte-carlo: maximize/minimize --monte-carlo-samples
  • stress-mmaptorture: maximize/minimize --mmaptorture-bytes, --mmaptorture-msync
  • stress-mmaphuge: maximize/minimize --mmaphuge-mmaps
  • stress-mmapfork: maximize --mmapfork-bytes
  • stress-mlockmany: maximize/minimize --mlockmany-procs
  • Manual: fix missing title for mmapmany stressor
  • stress-malloc: maximize/minimize --malloc-pthreads
  • stress-jpeg: maximize/minimize --jpeg-height, --jpeg-width, --jpeg-quality
  • stress-ipsec-mb: maximize/minimize --ipsec-mb-jobs
  • stress-io-uring: maximize/minimize --io-uring-entries
  • Manual: remove idle-page help
  • stress-icmp-flood: maximize/minimize --icmp-flood-max-size
  • stress-fractal: maximize/minimize --fractal-iterations, --fractal-sizex, --fractal-sizey
  • stress-fpunch: maximize/minimize --fpunch-bytes
  • stress-forkheavy: maximize/minimize --forkheavy-allocs, --forkheavy-procs
  • stress-flipflop: maximize/minimize --flipflop-bits
  • stress-fifo: maximize/minimize --fifo-data-size
  • stress-fd-fork: maximize/minimize --fd-fork-fds
  • stress-far-branch: maximize/minimize --far-branch-pages
  • stress-factor: maximize/minimize --factor-digits
  • stress-exec: maximize/minimize --exec-max
  • stress-ng: fix help, iostate -> iostat
  • stress-epoll: maximize/minimize --epoll-sockets
  • stress-dirmany: maximize/minimize --dirmany-bytes
  • stress-dir: maximize/minimize --dir-dirs
  • stress-dccp: maximize/minimize dccp-msgs
  • stress-chdir: maximize/minimize chdir-dirs
  • stress-bigheap: maximize/minimize bigheap-bytes
  • stress-malloc: flush pages when using --aggressive
  • core-resources: ensure all mapped pages are touched
  • stress-bigheap: use memory clearing calloc when using --aggressive
  • stress-vm: flush pages when using --aggressive
  • stress-vm-addr: flush pages when using --aggressive
  • stress-vma: flush pages when using --aggressive
  • stress-stack: flush touched stack pages when using --aggressive
  • stress-stack: make --stack-fill option fill stack with random data
  • stress-workload: use stress_cpu_data_cache_flush to flush data
  • stress-tlb-shoodown: use stress_cpu_data_cache_flush to flush data
  • stress-sysbadaddr: use stress_cpu_data_cache_flush to flush page
  • stress-sigsegv: use stress_cpu_data_cache_flush to flush data
  • stress-mcontend: use stress_cpu_data_cache_flush to flush cache line
  • stress-prefetch: use stress_cpu_data_cache_flush for cache flushing
  • core-cpu-cache: increment addr by cache line size
  • core-cpu-cache: add more optimized data cache flush helper
  • stress-pageswap: madvise populate read when using --aggressive option
  • stress-munmap: for pages to page out with --aggressive option
  • stress-madvise: force more swapouts/swapins with --aggressive options
  • core-out-of-memory: Fix off-by-one array overflow error
  • stess-bigheap: increase reallocs and memory checks with --aggressive
  • stress-affinity: add more sched_setaffinity call with --aggressive option
  • stress-access: add more access calls with --aggressive option enabled
  • stress-lockbus: add 1 byte and 2 byte misaligned 32 bit lock bus operations
  • stress-ng: enable specifying number of instances as % of cpus
  • core-, stress-: rename num_instances to instances
  • core-vmstat: add vmstat memory scaling option --vmstat-units U

Don't miss a new stress-ng release

NewReleases is sending notifications on new releases.