On Fri, Nov 15, 2013 at 08:24:36AM -0700, Aldy Hernandez wrote:
> Looks like we need to wait on Intel to pontificate on whether UDRs
> are valid or not.  Who knows...maybe no work at all!  Woo hoo!
> 
> How does this look?

Looks good to me, but please wait if Jason doesn't have any feedback too.

> gcc/ChangeLog.pragmasimd
> 
>       * Makefile.in (C_COMMON_OBJS): Depend on c-cilkplus.o.
>       * gimple-pretty-print.c (dump_omp_for): Add case for
>       GF_OMP_FOR_KIND_CILKSIMD.
>       * gimple.h (enum gf_mask): Restructure entries to add
>       GF_OMP_FOR_KIND_CILKSIMD.
>       * gimplify.c (is_gimple_stmt): Add case for CILK_SIMD.
>       (gimplify_omp_for): Handle CILK_SIMD.
>       (gimplify_expr): Add ccase for CILK_SIMD.
>       * omp-low.c (extract_omp_for_data): Handle CILK_SIMD.
>       (build_outer_var_ref): Same.
>       (check_omp_nesting_restrictions): Same.
>       (lower_rec_input_clauses): Same.
>       (lower_lastprivate_clauses): Same.
>       (expand_omp_for): Same.
>       (execute_expand_omp): Check flag_enable_cilkplus.
>       (execute_lower_omp): Same.
>       (diagnose_sb_0): Handle CILK_SIMD.
>       (diagnose_omp_structured_block_errors): Check
>       flag_enable_cilkplus.
>       (setjmp_or_longjmp_p): New.
>       (scan_omp_1_stmt): Error on setjmp/longjmp in a simd construct.
>       * tree-pretty-print.c (dump_generic_node): Add case for CILK_SIMD.
>       * tree.def: Add tree code for CILK_SIMD.
> 
> testsuite/
>       * c-c++-common/cilk-plus/PS: New directory.
>       * g++.dg/cilk-plus/cilk-plus.exp: Run shared tests.
>       * g++.dg/dg.exp: Run Cilk Plus tests.
>       * gcc.dg/cilk-plus/cilk-plus.exp: Run shared tests.
> 
> c-family/
>       * c-cilkplus.c: New file.
>       * c-common.c (readonly_error): Add location argument.
>       * c-common.h (readonly_error): Same.
>       (c_finish_cilk_clauses): Protoize.
>       (c_check_cilk_loop): Same.
>       c-omp.c (c_finish_omp_for): Handle CILK_SIMD nodes.
>       Do not fail on error_mark_node.
>       Abstract increment canonicalization to here...
>       (c_omp_for_incr_canonicalize_ptr): New.
>       c-pragma.c (init_pragma): Register "simd" pragma.
>       c-pragma.h (enum pragma_kind): Add PRAGMA_CILK_SIMD.
>       (enum pragma_cilk_clause): New.
> 
> c/
>       * c-parser.c (c_parser_cilk_simd): New.
>       (c_parser_cilk_verify_simd): New.
>       (c_parser_pragma): Add case for PRAGMA_CILK_SIMD.
>       (c_parser_omp_for_loop): Add case for NE_EXPR.
>       Set c_break_label for CILK_SIMD.
>       (c_parser_cilk_clause_vectorlength): New.
>       (c_parser_cilk_clause_linear): New.
>       (c_parser_cilk_clause_name): New.
>       (c_parser_cilk_all_clauses): New.
>       * c-typeck.c (build_unary_op): Pass location argument to
>       readonly_error.
>       (build_modify_expr): Same.
>       (build_asm_expr): Same.
>       (c_finish_bc_stmt): Error on break/continue in loops.
> 
> cp/
>       * Make-lang.in (CXX_AND_OBJCXX_OBJS): Depend on cp/cp-cilkplus.o.
>       * cp-cilkplus.c: New file.
>       * cp-tree.h (cpp_validate_cilk_plus_loop): Protoize.
>       * parser.c (cp_parser_cilk_simd): New.
>       (cp_debug_parser): Add case for IN_CILK_SIMD_FOR.
>       (cp_parser_jump_statement): Same.
>       (cp_parser_omp_for_cond): Add new argument.
>       Add case for NE_EXPR.
>       (cp_parser_omp_for_loop): Pass new argument to
>       cp_parser_omp_for_cond.
>       Handle CILK_SIMD nodes.
>       Abstract initilization code to..
>       (cp_parser_omp_for_loop_init): ...here.
>       (cp_parser_pragma): Add case for PRAGMA_CILK_SIMD.
>       (cp_parser_cilk_simd_vectorlength): New.
>       (cp_parser_cilk_simd_linear): New.
>       (cp_parser_cilk_simd_clause_name): New.
>       (cp_parser_cilk_simd_all_clauses): New.
>       (cp_parser_cilk_simd): New.
>       * parser.h (IN_CILK_SIMD_FOR): New macro.
>       * pt.c (tsubst_expr): Add case for CILK_SIMD.
>       * typeck2.c (cxx_readonly_error): Pass location argument to
>       readonly_error.

        Jakub

Reply via email to