X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=gdb%2Fc-exp.h;h=1a69b1c79600e9a61c73a11c1a63d2c089e03c20;hb=088463f10fa7279764b414bf9b296bf27f214d03;hp=2d224c8c633dfbb51e2e7871a21db840bcc70bf3;hpb=085734dd954dd2b3da9445dc517bfdb10f9ca117;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/c-exp.h b/gdb/c-exp.h index 2d224c8c63..1a69b1c796 100644 --- a/gdb/c-exp.h +++ b/gdb/c-exp.h @@ -27,6 +27,23 @@ extern struct value *eval_op_objc_selector (struct type *expect_type, struct expression *exp, enum noside noside, const char *sel); +extern struct value *opencl_value_cast (struct type *type, struct value *arg); +extern struct value *eval_opencl_assign (struct type *expect_type, + struct expression *exp, + enum noside noside, + enum exp_opcode op, + struct value *arg1, + struct value *arg2); +extern struct value *opencl_relop (struct type *expect_type, + struct expression *exp, + enum noside noside, enum exp_opcode op, + struct value *arg1, struct value *arg2); +extern struct value *opencl_logical_not (struct type *expect_type, + struct expression *exp, + enum noside noside, + enum exp_opcode op, + struct value *arg); + namespace expr { @@ -57,8 +74,6 @@ public: struct expression *exp, enum noside noside) override { - if (noside == EVAL_SKIP) - return eval_skip_value (exp); const std::string &str = std::get<0> (m_storage); return value_nsstring (exp->gdbarch, str.c_str (), str.size () + 1); } @@ -78,8 +93,6 @@ public: struct expression *exp, enum noside noside) override { - if (noside == EVAL_SKIP) - return eval_skip_value (exp); return eval_op_objc_selector (expect_type, exp, noside, std::get<0> (m_storage).c_str ()); } @@ -105,6 +118,103 @@ public: { return OP_OBJC_MSGCALL; } }; +using opencl_cast_type_operation = cxx_cast_operation; + +/* Binary operations, as needed for OpenCL. */ +template> +class opencl_binop_operation + : public BASE +{ +public: + + using BASE::BASE; + + value *evaluate (struct type *expect_type, + struct expression *exp, + enum noside noside) override + { + value *lhs + = std::get<0> (this->m_storage)->evaluate (nullptr, exp, noside); + value *rhs + = std::get<1> (this->m_storage)->evaluate (value_type (lhs), exp, + noside); + return FUNC (expect_type, exp, noside, OP, lhs, rhs); + } + + enum exp_opcode opcode () const override + { return OP; } +}; + +using opencl_assign_operation = opencl_binop_operation; +using opencl_equal_operation = opencl_binop_operation; +using opencl_notequal_operation = opencl_binop_operation; +using opencl_less_operation = opencl_binop_operation; +using opencl_gtr_operation = opencl_binop_operation; +using opencl_geq_operation = opencl_binop_operation; +using opencl_leq_operation = opencl_binop_operation; + +using opencl_not_operation = unop_operation; + +/* STRUCTOP_STRUCT implementation for OpenCL. */ +class opencl_structop_operation + : public structop_base_operation +{ +public: + + using structop_base_operation::structop_base_operation; + + value *evaluate (struct type *expect_type, + struct expression *exp, + enum noside noside) override; + + enum exp_opcode opcode () const override + { return STRUCTOP_STRUCT; } +}; + +/* This handles the "&&" and "||" operations for OpenCL. */ +class opencl_logical_binop_operation + : public tuple_holding_operation +{ +public: + + using tuple_holding_operation::tuple_holding_operation; + + value *evaluate (struct type *expect_type, + struct expression *exp, + enum noside noside) override; + + enum exp_opcode opcode () const override + { return std::get<0> (m_storage); } +}; + +/* The ?: ternary operator for OpenCL. */ +class opencl_ternop_cond_operation + : public tuple_holding_operation +{ +public: + + using tuple_holding_operation::tuple_holding_operation; + + value *evaluate (struct type *expect_type, + struct expression *exp, + enum noside noside) override; + + enum exp_opcode opcode () const override + { return TERNOP_COND; } +}; + }/* namespace expr */ #endif /* C_EXP_H */