Skip to content
Snippets Groups Projects
Commit 9490fda6 authored by Ian Lance Taylor's avatar Ian Lance Taylor
Browse files

re PR go/61620 (FAIL: go.test/test/fixedbugs/bug242.go execution, -O2 -g)

	PR go/61620

runtime: Don't free tiny blocks in map deletion.

The memory allocator now has a special case for tiny blocks
(smaller than 16 bytes) and they can not be explicitly freed.

From-SVN: r212233
parent 513c5c74
No related branches found
No related tags found
No related merge requests found
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#include <stdlib.h> #include <stdlib.h>
#include "runtime.h" #include "runtime.h"
#include "malloc.h"
#include "go-alloc.h" #include "go-alloc.h"
#include "go-assert.h" #include "go-assert.h"
#include "map.h" #include "map.h"
...@@ -47,7 +48,8 @@ __go_map_delete (struct __go_map *map, const void *key) ...@@ -47,7 +48,8 @@ __go_map_delete (struct __go_map *map, const void *key)
if (equalfn (key, entry + key_offset, key_size)) if (equalfn (key, entry + key_offset, key_size))
{ {
*pentry = *(void **) entry; *pentry = *(void **) entry;
__go_free (entry); if (descriptor->__entry_size >= TinySize)
__go_free (entry);
map->__element_count -= 1; map->__element_count -= 1;
break; break;
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment