diff options
author | David Malcolm <dmalcolm@redhat.com> | 2015-01-08 01:08:19 +0000 |
---|---|---|
committer | David Malcolm <dmalcolm@gcc.gnu.org> | 2015-01-08 01:08:19 +0000 |
commit | c211cd236cb0b4cda31657cd96668aace2e8e4ac (patch) | |
tree | 025103f7b525c54f3336316a1945f7c1106cf5c0 /gcc/jit | |
parent | 5efe46fdc75546d4279d355b5e79280901238b09 (diff) | |
download | gcc-c211cd236cb0b4cda31657cd96668aace2e8e4ac.zip gcc-c211cd236cb0b4cda31657cd96668aace2e8e4ac.tar.gz gcc-c211cd236cb0b4cda31657cd96668aace2e8e4ac.tar.bz2 |
jit: Add checking for dereference of void *
gcc/jit/ChangeLog:
* jit-recording.h (gcc::jit::recording::type::is_void): New
virtual function.
(gcc::jit::recording::memento_of_get_type::is_void): New
function, overriding default implementation.
* libgccjit.c (gcc_jit_rvalue_dereference): Verify that
the underlying type is not "void".
gcc/testsuite/ChangeLog:
* jit.dg/test-error-dereferencing-void-ptr.c: New test case.
From-SVN: r219333
Diffstat (limited to 'gcc/jit')
-rw-r--r-- | gcc/jit/ChangeLog | 9 | ||||
-rw-r--r-- | gcc/jit/jit-recording.h | 2 | ||||
-rw-r--r-- | gcc/jit/libgccjit.c | 7 |
3 files changed, 18 insertions, 0 deletions
diff --git a/gcc/jit/ChangeLog b/gcc/jit/ChangeLog index b17706e..01b3882 100644 --- a/gcc/jit/ChangeLog +++ b/gcc/jit/ChangeLog @@ -1,5 +1,14 @@ 2015-01-07 David Malcolm <dmalcolm@redhat.com> + * jit-recording.h (gcc::jit::recording::type::is_void): New + virtual function. + (gcc::jit::recording::memento_of_get_type::is_void): New + function, overriding default implementation. + * libgccjit.c (gcc_jit_rvalue_dereference): Verify that + the underlying type is not "void". + +2015-01-07 David Malcolm <dmalcolm@redhat.com> + * docs/topics/expressions.rst (Unary Operations): Add GCC_JIT_UNARY_OP_ABS. * jit-playback.c (gcc::jit::playback::context::new_unary_op): diff --git a/gcc/jit/jit-recording.h b/gcc/jit/jit-recording.h index 3734e9a..9034e11 100644 --- a/gcc/jit/jit-recording.h +++ b/gcc/jit/jit-recording.h @@ -443,6 +443,7 @@ public: virtual bool is_bool () const = 0; virtual type *is_pointer () = 0; virtual type *is_array () = 0; + virtual bool is_void () const { return false; } bool is_numeric () const { @@ -494,6 +495,7 @@ public: bool is_bool () const; type *is_pointer () { return dereference (); } type *is_array () { return NULL; } + bool is_void () const { return m_kind == GCC_JIT_TYPE_VOID; } public: void replay_into (replayer *r); diff --git a/gcc/jit/libgccjit.c b/gcc/jit/libgccjit.c index 6853bb0..99b2d56 100644 --- a/gcc/jit/libgccjit.c +++ b/gcc/jit/libgccjit.c @@ -1664,6 +1664,13 @@ gcc_jit_rvalue_dereference (gcc_jit_rvalue *rvalue, rvalue->get_debug_string (), rvalue->get_type ()->get_debug_string ()); + RETURN_NULL_IF_FAIL_PRINTF2 ( + !underlying_type->is_void (), + rvalue->m_ctxt, loc, + "dereference of void pointer %s (type: %s)", + rvalue->get_debug_string (), + rvalue->get_type ()->get_debug_string ()); + return (gcc_jit_lvalue *)rvalue->dereference (loc); } |