Commit d431291
authored
feat(deserialize): prevent unbound allocation (#129)
With a crafted input, a malformed data of just four bytes may lead to
allocation of 4 GiB. This may lead to OOM on constrained environments
(e.g. inside of a container with memory limits set or on 32-bit
machines).
(This once again shows Rust desperately needs full specialisation. We
may dream of time that it ever comes…)1 parent d915ab5 commit d431291
1 file changed
+23
-4
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
144 | 144 | | |
145 | 145 | | |
146 | 146 | | |
147 | | - | |
148 | | - | |
149 | | - | |
150 | | - | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
151 | 170 | | |
152 | 171 | | |
153 | 172 | | |
| |||
0 commit comments