This patch series introduces support for the target_clones table option in GCC. This option enables users to specify target_clones attributes in a separate file, allowing GCC to generate multiple versions of the function with different ISA extensions based on the specified table. This is achieved using the -ftarget-clones-table option.
The primary objective of this patch series is to provide a user-friendly way to specify target_clones attributes without modifying the source code. This approach enhances the source code's cleanliness, facilitates easier maintenance, and ensures portability across different architectures and compiler versions. A example usage is shown below: Say we have a function `foo` in C source code `foo.c`. Then we have a target clones table file `target_clones.json`: ```json { "foo": { "x86_64": ["avx2", "avx512f"], "riscv64": ["arch=+v", "arch=+zba,+zbb", ...], ... // more architectures }, // more functions } ``` Then use: `gcc -O3 -ftarget-clones-table=target_clones.json -S foo.c` to compile the source code. This will generate multiple versions of the `foo` function with the specified target clones attributes for each architecture. Changes in v3: - Rebase to the latest master branch - Skip unsupported C++ virtual functions - Merge table clones table with attributes instead of replacing them - Add a testcase v2: https://patchwork.sourceware.org/project/gcc/cover/tencent_815f8860ae36bfa3102e4ecc77c843231...@qq.com/ Changes in v2: - Use the name of "-ftarget-clones-table" instead of "-ftarget-profile" - Use JSON formatted table instead of a text file - Each architectures like x86_64, aarch64, riscv64, etc. Can specify multiple target clones attributes in a single JSON table, which makes it more flexible and easier to use. v1: https://patchwork.sourceware.org/project/gcc/cover/tencent_7e345ef1390b9a68a738cee15ec510864...@qq.com/ Yangyu Chen (3): Fortran: Do not make_decl_rtl in trans_function_start json: add iterate method to object class fmv: Add -ftarget-clones-table option support gcc/Makefile.in | 1 + gcc/common.opt | 7 ++ gcc/fortran/trans-decl.cc | 3 - gcc/json.h | 5 + gcc/multiple_target.cc | 138 +++++++++++++++++++++-- gcc/testsuite/gcc.target/i386/tct-0.c | 11 ++ gcc/testsuite/gcc.target/i386/tct-0.json | 5 + 7 files changed, 157 insertions(+), 13 deletions(-) create mode 100644 gcc/testsuite/gcc.target/i386/tct-0.c create mode 100644 gcc/testsuite/gcc.target/i386/tct-0.json -- 2.49.0