mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-01-15 01:29:11 +08:00
prepare readme for release
This commit is contained in:
parent
79f31b0e8f
commit
8ecbc29a02
39
readme.md
39
readme.md
@ -12,15 +12,15 @@ is a general purpose allocator with excellent [performance](#performance) charac
|
|||||||
Initially developed by Daan Leijen for the run-time systems of the
|
Initially developed by Daan Leijen for the run-time systems of the
|
||||||
[Koka](https://koka-lang.github.io) and [Lean](https://github.com/leanprover/lean) languages.
|
[Koka](https://koka-lang.github.io) and [Lean](https://github.com/leanprover/lean) languages.
|
||||||
|
|
||||||
Latest release tag: `v2.0.9` (2022-12-23).
|
Latest release tag: `v2.1.0` (2023-03-29).
|
||||||
Latest stable tag: `v1.7.9` (2022-12-23).
|
Latest stable tag: `v1.8.0` (2023-03-29).
|
||||||
|
|
||||||
mimalloc is a drop-in replacement for `malloc` and can be used in other programs
|
mimalloc is a drop-in replacement for `malloc` and can be used in other programs
|
||||||
without code changes, for example, on dynamically linked ELF-based systems (Linux, BSD, etc.) you can use it as:
|
without code changes, for example, on dynamically linked ELF-based systems (Linux, BSD, etc.) you can use it as:
|
||||||
```
|
```
|
||||||
> LD_PRELOAD=/usr/lib/libmimalloc.so myprogram
|
> LD_PRELOAD=/usr/lib/libmimalloc.so myprogram
|
||||||
```
|
```
|
||||||
It also has an easy way to override the default allocator in [Windows](#override_on_windows). Notable aspects of the design include:
|
It also includes a robust way to override the default allocator in [Windows](#override_on_windows). Notable aspects of the design include:
|
||||||
|
|
||||||
- __small and consistent__: the library is about 8k LOC using simple and
|
- __small and consistent__: the library is about 8k LOC using simple and
|
||||||
consistent data structures. This makes it very suitable
|
consistent data structures. This makes it very suitable
|
||||||
@ -78,6 +78,10 @@ Note: the `v2.x` version has a new algorithm for managing internal mimalloc page
|
|||||||
and fragmentation compared to mimalloc `v1.x` (especially for large workloads). Should otherwise have similar performance
|
and fragmentation compared to mimalloc `v1.x` (especially for large workloads). Should otherwise have similar performance
|
||||||
(see [below](#performance)); please report if you observe any significant performance regression.
|
(see [below](#performance)); please report if you observe any significant performance regression.
|
||||||
|
|
||||||
|
* 2023-03-29, `v1.8.0`, `v2.1.0`: Improved support dynamic overriding on Windows 11. Improved tracing precision
|
||||||
|
with [#asan] and [#Valgrind], and added Windows event tracing [#ETW] (contributed by Xinglong He). Created an OS
|
||||||
|
abstraction layer to make it easier to port and separate platform dependent code (in `src/prim`). Fixed C++ STL compilation on older Microsoft C++ compilers, and various small bug fixes.
|
||||||
|
|
||||||
* 2022-12-23, `v1.7.9`, `v2.0.9`: Supports building with [#asan] and improved [#Valgrind] support. Support abitrary large
|
* 2022-12-23, `v1.7.9`, `v2.0.9`: Supports building with [#asan] and improved [#Valgrind] support. Support abitrary large
|
||||||
alignments (in particular for `std::pmr` pools).
|
alignments (in particular for `std::pmr` pools).
|
||||||
Added C++ STL allocators attached to a specific heap (thanks @vmarkovtsev).
|
Added C++ STL allocators attached to a specific heap (thanks @vmarkovtsev).
|
||||||
@ -351,6 +355,7 @@ When _mimalloc_ is built using debug mode, various checks are done at runtime to
|
|||||||
|
|
||||||
Generally, we recommend using the standard allocator with memory tracking tools, but mimalloc
|
Generally, we recommend using the standard allocator with memory tracking tools, but mimalloc
|
||||||
can also be build to support the [address sanitizer][asan] or the excellent [Valgrind] tool.
|
can also be build to support the [address sanitizer][asan] or the excellent [Valgrind] tool.
|
||||||
|
Moreover, it can be build to support Windows event tracing ([ETW]).
|
||||||
This has a small performance overhead but does allow detecting memory leaks and byte-precise
|
This has a small performance overhead but does allow detecting memory leaks and byte-precise
|
||||||
buffer overflows directly on final executables. See also the `test/test-wrong.c` file to test with various tools.
|
buffer overflows directly on final executables. See also the `test/test-wrong.c` file to test with various tools.
|
||||||
|
|
||||||
@ -417,6 +422,24 @@ Adress sanitizer support is in its initial development -- please report any issu
|
|||||||
|
|
||||||
[asan]: https://github.com/google/sanitizers/wiki/AddressSanitizer
|
[asan]: https://github.com/google/sanitizers/wiki/AddressSanitizer
|
||||||
|
|
||||||
|
### ETW
|
||||||
|
|
||||||
|
Event tracing for Windows ([ETW]) provides a high performance way to capture all allocations though
|
||||||
|
mimalloc and analyze them later. To build with ETW support, use the `-DMI_TRACE_ETW=ON` cmake option.
|
||||||
|
|
||||||
|
You can then capture an allocation trace using the Windows performance recorder (WPR), using the
|
||||||
|
`src/prim/windows/etw-mimalloc.wprp` profile. In an admin prompt, you can use:
|
||||||
|
```
|
||||||
|
> wpr -start src\prim\windows\etw-mimalloc.wprp -filemode
|
||||||
|
> <my_mimalloc_program>
|
||||||
|
> wpr -stop <my_mimalloc_program>.etl
|
||||||
|
```
|
||||||
|
and then open `<my_mimalloc_program>.etl` in the Windows Performance Analyzer (WPA), or
|
||||||
|
use a tool like [TraceControl] that is specialized for analyzing mimalloc traces.
|
||||||
|
|
||||||
|
[ETW]: https://learn.microsoft.com/en-us/windows-hardware/test/wpt/event-tracing-for-windows
|
||||||
|
[TraceControl]: https://github.com/xinglonghe/TraceControl
|
||||||
|
|
||||||
|
|
||||||
# Overriding Standard Malloc
|
# Overriding Standard Malloc
|
||||||
|
|
||||||
@ -426,7 +449,7 @@ Overriding the standard `malloc` (and `new`) can be done either _dynamically_ or
|
|||||||
|
|
||||||
This is the recommended way to override the standard malloc interface.
|
This is the recommended way to override the standard malloc interface.
|
||||||
|
|
||||||
### Override on Linux, BSD
|
### Dynamic Override on Linux, BSD
|
||||||
|
|
||||||
On these ELF-based systems we preload the mimalloc shared
|
On these ELF-based systems we preload the mimalloc shared
|
||||||
library so all calls to the standard `malloc` interface are
|
library so all calls to the standard `malloc` interface are
|
||||||
@ -445,7 +468,7 @@ or run with the debug version to get detailed statistics:
|
|||||||
> env MIMALLOC_SHOW_STATS=1 LD_PRELOAD=/usr/lib/libmimalloc-debug.so myprogram
|
> env MIMALLOC_SHOW_STATS=1 LD_PRELOAD=/usr/lib/libmimalloc-debug.so myprogram
|
||||||
```
|
```
|
||||||
|
|
||||||
### Override on MacOS
|
### Dynamic Override on MacOS
|
||||||
|
|
||||||
On macOS we can also preload the mimalloc shared
|
On macOS we can also preload the mimalloc shared
|
||||||
library so all calls to the standard `malloc` interface are
|
library so all calls to the standard `malloc` interface are
|
||||||
@ -458,7 +481,7 @@ Note that certain security restrictions may apply when doing this from
|
|||||||
the [shell](https://stackoverflow.com/questions/43941322/dyld-insert-libraries-ignored-when-calling-application-through-bash).
|
the [shell](https://stackoverflow.com/questions/43941322/dyld-insert-libraries-ignored-when-calling-application-through-bash).
|
||||||
|
|
||||||
|
|
||||||
### Override on Windows
|
### Dynamic Override on Windows
|
||||||
|
|
||||||
<span id="override_on_windows">Overriding on Windows</span> is robust and has the
|
<span id="override_on_windows">Overriding on Windows</span> is robust and has the
|
||||||
particular advantage to be able to redirect all malloc/free calls that go through
|
particular advantage to be able to redirect all malloc/free calls that go through
|
||||||
@ -491,13 +514,13 @@ Such patching can be done for example with [CFF Explorer](https://ntcore.com/?pa
|
|||||||
|
|
||||||
On Unix-like systems, you can also statically link with _mimalloc_ to override the standard
|
On Unix-like systems, you can also statically link with _mimalloc_ to override the standard
|
||||||
malloc interface. The recommended way is to link the final program with the
|
malloc interface. The recommended way is to link the final program with the
|
||||||
_mimalloc_ single object file (`mimalloc-override.o`). We use
|
_mimalloc_ single object file (`mimalloc.o`). We use
|
||||||
an object file instead of a library file as linkers give preference to
|
an object file instead of a library file as linkers give preference to
|
||||||
that over archives to resolve symbols. To ensure that the standard
|
that over archives to resolve symbols. To ensure that the standard
|
||||||
malloc interface resolves to the _mimalloc_ library, link it as the first
|
malloc interface resolves to the _mimalloc_ library, link it as the first
|
||||||
object file. For example:
|
object file. For example:
|
||||||
```
|
```
|
||||||
> gcc -o myprogram mimalloc-override.o myfile1.c ...
|
> gcc -o myprogram mimalloc.o myfile1.c ...
|
||||||
```
|
```
|
||||||
|
|
||||||
Another way to override statically that works on all platforms, is to
|
Another way to override statically that works on all platforms, is to
|
||||||
|
Loading…
x
Reference in New Issue
Block a user