Daniel Micay
d0b466beb8
elaborate on the cost of GUARD_SLABS_INTERVAL
2019-08-18 05:46:20 -04:00
Daniel Micay
7a8c57d0f5
stop marking MPK support 'extremely experimental'
2019-08-18 05:37:42 -04:00
Daniel Micay
c4fc025fde
clarify ZERO_ON_FREE / WRITE_AFTER_FREE_CHECK
2019-08-18 05:35:48 -04:00
Daniel Micay
125efe99db
fix wording in note about malloc_object_size
2019-08-18 02:51:32 -04:00
Daniel Micay
abece7656b
add enabled-by-default option to use -Werror
2019-08-18 02:28:23 -04:00
Daniel Micay
defd55f302
provide link to Bionic integration commit
2019-08-18 01:44:40 -04:00
Daniel Micay
04f69d9f0d
update supported Android branches
2019-08-18 01:41:56 -04:00
Daniel Micay
995d0580d1
remove extra spaces inserted by vim joinspaces
2019-08-18 01:39:22 -04:00
Daniel Micay
b6b910f032
add table of contents to README
2019-08-18 01:15:54 -04:00
Daniel Micay
24de5aab05
still need to finish up initial malloc_object_size
2019-08-18 01:15:54 -04:00
Daniel Micay
71e4577367
fix some inconsistencies in the tagging examples
2019-08-13 21:44:16 -04:00
Daniel Micay
3ed6e546c8
OS integration guide
2019-07-18 07:22:29 -04:00
Daniel Micay
7bcfa500be
remove note about lack of sanity checks for config
2019-07-11 15:50:45 -04:00
Daniel Micay
72a08f88fb
supports Debian oldstable due to Buster release
2019-07-10 18:08:14 -04:00
Daniel Micay
934ab4cb59
explain extended size classes impact on quarantine
2019-07-05 17:57:41 -04:00
Daniel Micay
060f74b993
extended size classes now go up to 128k not 64k
2019-07-05 17:55:25 -04:00
Daniel Micay
4d4277319a
clarifications to randomization documentation
2019-06-23 19:20:16 -04:00
Daniel Micay
37474e117c
limit precision for fragmentation in table
2019-06-12 13:29:04 -04:00
Daniel Micay
64a1f59020
note about getrandom with syscall whitelists
2019-06-02 22:24:25 -04:00
Daniel Micay
ae4142c2d1
note that arenas are isolated from each other
2019-04-23 02:01:44 -04:00
Daniel Micay
18f36c3e8d
expand description of randomized delay free
2019-04-23 01:59:31 -04:00
Daniel Micay
7f0bbddfca
merge points about out-of-line / protected state
2019-04-23 01:58:37 -04:00
Daniel Micay
086eb1fee4
at a final spacing class of 1 slot size classes
2019-04-10 16:32:24 -04:00
Daniel Micay
b31e8dacb1
document extended size classes
2019-04-10 08:42:32 -04:00
Daniel Micay
922c741915
it already supports Bionic, musl and glibc
2019-04-07 18:13:26 -04:00
Daniel Micay
e0891c8cfc
implement the option of large size classes
...
This extends the size class scheme used for slab allocations to large
allocations. This drastically improves performance for many real world
programs using incremental realloc growth instead of using proper growth
factors. There are 4 size classes for every doubling in size, resulting
in a worst case of ~20% extra virtual memory being reserved and a huge
increase in performance for pathological cases. For example, growing
from 4MiB to 8MiB by calling realloc in increments of 32 bytes will only
need to do work beyond looking up the size 4 times instead of 1024 times
with 4096 byte granularity.
2019-04-07 08:52:17 -04:00
Daniel Micay
ec8fb347ed
document CONFIG_STATS
2019-04-07 00:10:22 -04:00
Daniel Micay
beaa39a5a3
move to only supporting current generation AOSP
2019-04-06 23:46:35 -04:00
Daniel Micay
494cc5ec50
update README now that arenas are implemented
2019-03-25 16:18:01 -04:00
Daniel Micay
c5e911419d
add initial implementation of arenas
2019-03-25 14:59:50 -04:00
Daniel Micay
ddd616aa0b
add documentation on system calls
2019-03-20 11:59:58 -04:00
Daniel Micay
ae96835b94
fix scalability header levels
2019-02-04 15:59:14 -05:00
Daniel Micay
e4061899aa
add documentation on scalability design choices
2019-02-04 15:01:15 -05:00
Daniel Micay
41df5005e8
add a top-level header to the README
2019-02-04 13:59:19 -05:00
Daniel Micay
9cc0ac3efa
add basic documentation on memory tagging approach
2019-02-04 11:58:28 -05:00
Daniel Micay
33b1a2740e
update default slab quarantine sizes in README
2019-01-02 15:42:41 -05:00
Arlo Breault
dea2788539
fix typo in README.md
2019-01-02 15:40:58 -05:00
Daniel Micay
57f115b33c
scale slab quarantine based on size
2019-01-02 14:52:13 -05:00
Daniel Micay
ccc2a86501
rename quarantine size -> length for clarity
2019-01-02 14:17:02 -05:00
Daniel Micay
830a7d338d
make class_region_size configurable
2018-12-05 09:38:13 -05:00
Daniel Micay
11fe467b7c
clarify wording
2018-11-19 08:04:37 -05:00
Daniel Micay
c9dfe586b3
add initial documentation on API extensions
2018-11-19 06:54:48 -05:00
Daniel Micay
4d85a61db2
remove obsolete duplicate information
2018-11-19 06:31:58 -05:00
Daniel Micay
d88a8c9813
mention that the same hash table code is reused
2018-11-19 05:45:34 -05:00
Daniel Micay
433b37b4a9
explain more of the size class reasoning
2018-11-19 01:44:46 -05:00
Daniel Micay
a052be762d
explain some differences from the previous project
2018-11-19 01:08:53 -05:00
Daniel Micay
a5ed64d01a
explain slot counts tied to slab size classes
2018-11-19 00:29:18 -05:00
Daniel Micay
5b048a28c2
improve explanation of jemalloc size classes
2018-11-19 00:29:15 -05:00
Daniel Micay
ac99282773
remove duplicate word
2018-11-17 10:53:04 -05:00
Daniel Micay
54a0313d9b
split out dependencies section
2018-11-16 18:41:27 -05:00
Daniel Micay
d208d093a2
add more of an introduction describing the project
2018-11-16 18:39:19 -05:00
Daniel Micay
2bb568b473
improve documentation about mapping count
2018-11-16 18:04:46 -05:00
Daniel Micay
8a38c4fb2a
add initial documentation for integer options
2018-11-16 15:40:48 -05:00
Daniel Micay
f3623e1f2b
finish migration away from config.h
2018-11-16 15:40:45 -05:00
Daniel Micay
315415acf2
clarify write-after-free detection feature
2018-11-16 03:26:07 -05:00
Daniel Micay
11c717a7b9
update progress on randomization
2018-11-05 18:06:54 -05:00
Daniel Micay
2d892e58ad
per-slab canary values are good enough for now
2018-11-05 18:05:56 -05:00
Daniel Micay
3a488c9a27
add initial slab allocation quarantine
2018-11-05 16:43:08 -05:00
Daniel Micay
ca465f6b3e
clarify scope of sized dealloc mismatch detection
2018-11-04 18:52:01 -05:00
Daniel Micay
1fed72a9c3
slab internal fragmentation is always the same
2018-11-04 03:59:54 -05:00
Daniel Micay
c12d6795de
expand a bit on future config for slab cache size
2018-11-03 04:47:45 -04:00
Daniel Micay
d5b773b2bc
clarify documentation about the 0 byte size class
2018-11-03 04:43:47 -04:00
Daniel Micay
f949698c7a
note that MPK-based hardening is off by default
2018-11-03 03:15:42 -04:00
Daniel Micay
f2a7ccde75
add basic overview of part of the approach to MTE
2018-11-03 03:09:03 -04:00
Daniel Micay
1da51ddde1
migrate bool configuration options out of config.h
2018-11-02 21:35:09 -04:00
Daniel Micay
5bee717134
use -march=native by default with a disable toggle
2018-10-28 22:49:15 -04:00
Daniel Micay
6f30211da8
some clarifications for the README
2018-10-28 20:28:10 -04:00
Daniel Micay
e985afe0e1
document relatively high performance cost of MPK
2018-10-23 19:38:48 -04:00
Daniel Micay
0b963078d5
guard metadata with Memory Protection Keys (MPK)
2018-10-23 01:11:31 -04:00
Daniel Micay
64b655f062
set scope of planned metadata protection
2018-10-18 20:35:25 -04:00
Daniel Micay
e37b36c9dd
update configuration documentation again
2018-10-18 20:18:55 -04:00
Daniel Micay
cf053e74d1
metadata region unification is completed
2018-10-18 16:10:49 -04:00
Daniel Micay
74139112d0
explain the purpose of CONFIG_CXX_ALLOCATOR
2018-10-18 14:57:33 -04:00
Daniel Micay
da8e9aa1d8
document allocator state region
2018-10-15 15:44:31 -04:00
Daniel Micay
e8eca2d430
explain the production-oriented design rationale
2018-10-15 04:07:20 -04:00
Daniel Micay
124d958da1
document free slabs quarantine
2018-10-14 22:19:10 -04:00
Daniel Micay
3504465584
document progress on protected allocator state
2018-10-14 22:15:48 -04:00
Daniel Micay
0a64c7d6a1
document the randomized array in the quarantine
2018-10-12 15:10:35 -04:00
Daniel Micay
2381d973b1
expand on metadata address space security
2018-10-10 18:55:31 -04:00
Daniel Micay
29fd86ab37
document sized deallocation validation
2018-10-10 18:49:17 -04:00
Daniel Micay
1a10c17e8b
add quarantine for large allocations
2018-10-08 16:14:07 -04:00
Daniel Micay
cf07ae6007
update configuration in README
2018-10-06 15:38:09 -04:00
Daniel Micay
e6e9ac1fc9
support replacing C++ new/delete implementation
...
This adds support for sanity checks based on sized deallocation and will
reduce the overhead of calls through the C++ allocator.
2018-10-05 02:11:29 -04:00
Daniel Micay
08a633b244
fix another typo in the README
2018-10-04 04:12:21 -04:00
Daniel Micay
e99191d5d4
document tuning vm.max_map_count
2018-10-04 03:44:19 -04:00
Daniel Micay
d12cf324dd
add documentation on testing
2018-10-04 03:27:30 -04:00
Daniel Micay
2a31c7291b
add basic documentation on configuration
2018-10-04 03:15:55 -04:00
Daniel Micay
15e5e2d0ac
fix typo in README
2018-10-03 17:23:20 -04:00
Daniel Micay
b24569b6ca
zero leading byte of canaries
2018-10-03 17:09:57 -04:00
Daniel Micay
b52d9ca831
aggressive write-after-free check is implemented
2018-09-11 05:17:22 -04:00
Daniel Micay
3751b85e47
document minimum musl version for external use
2018-09-06 19:52:09 -04:00
Daniel Micay
1be74ec40d
add initial guard slabs implementation
2018-09-06 18:55:24 -04:00
Daniel Micay
bf55fad6d0
document that slab canaries are implemented
2018-09-05 00:19:27 -04:00
Daniel Micay
2ec65306dd
expand documentation on supported environments
2018-09-02 06:05:37 -04:00
Daniel Micay
e93d039214
only use reserved memory for regions hash table
2018-09-01 10:23:06 -04:00
Daniel Micay
dba330fde7
expand documentation in the README
2018-08-30 11:12:43 -04:00
Daniel Micay
b424c95737
clarify memory is zero on init without more writes
2018-08-27 01:14:36 -04:00
Daniel Micay
1b3d485e87
clarify that the slab design isn't like jemalloc
2018-08-26 07:19:58 -04:00
Daniel Micay
c97bbc141c
add missing word
2018-08-26 07:11:22 -04:00
Daniel Micay
f793a2719f
add some basic initial documentation to the README
2018-08-26 06:39:33 -04:00