summaryrefslogtreecommitdiff
path: root/include/exec/user
diff options
context:
space:
mode:
authorAlexander Graf <agraf@suse.de>2015-05-06 23:47:32 +0200
committerRiku Voipio <riku.voipio@linaro.org>2015-06-15 11:36:58 +0300
commit8be656b87c6bb1b9f8af3ff78094413d71e4443a (patch)
tree08875ef1e84bb8197351907214f605a263e3329d /include/exec/user
parent0a2df857a7038c75379cc575de5d4be4c0ac629e (diff)
downloadqemu-8be656b87c6bb1b9f8af3ff78094413d71e4443a.zip
linux-user: Allocate thunk size dynamically
We store all struct types in an array of static size without ever checking whether we overrun it. Of course some day someone (like me in another, ancient ALSA enabling patch set) will run into the limit without realizing it. So let's make the allocation dynamic. We already know the number of structs that we want to allocate, so we only need to pass the variable into the respective piece of code. Also, to ensure we don't accidently overwrite random memory, add some asserts to sanity check whether a thunk is actually part of our array. Signed-off-by: Alexander Graf <agraf@suse.de> Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
Diffstat (limited to 'include/exec/user')
-rw-r--r--include/exec/user/thunk.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/include/exec/user/thunk.h b/include/exec/user/thunk.h
index 87025c3b04..3b67462726 100644
--- a/include/exec/user/thunk.h
+++ b/include/exec/user/thunk.h
@@ -74,7 +74,7 @@ const argtype *thunk_convert(void *dst, const void *src,
const argtype *type_ptr, int to_host);
#ifndef NO_THUNK_TYPE_SIZE
-extern StructEntry struct_entries[];
+extern StructEntry *struct_entries;
int thunk_type_size_array(const argtype *type_ptr, int is_host);
int thunk_type_align_array(const argtype *type_ptr, int is_host);
@@ -186,4 +186,6 @@ unsigned int target_to_host_bitmask(unsigned int x86_mask,
unsigned int host_to_target_bitmask(unsigned int alpha_mask,
const bitmask_transtbl * trans_tbl);
+void thunk_init(unsigned int max_structs);
+
#endif