diff options
author | Martin Liska <mliska@suse.cz> | 2022-01-14 16:56:44 +0100 |
---|---|---|
committer | Martin Liska <mliska@suse.cz> | 2022-01-17 22:12:04 +0100 |
commit | 5c69acb32329d49e58c26fa41ae74229a52b9106 (patch) | |
tree | ddb05f9d73afb6f998457d2ac4b720e3b3b60483 /gcc/cgraphunit.c | |
parent | 490e23032baaece71f2ec09fa1805064b150fbc2 (diff) | |
download | gcc-5c69acb32329d49e58c26fa41ae74229a52b9106.zip gcc-5c69acb32329d49e58c26fa41ae74229a52b9106.tar.gz gcc-5c69acb32329d49e58c26fa41ae74229a52b9106.tar.bz2 |
Rename .c files to .cc files.
gcc/ada/ChangeLog:
* adadecode.c: Moved to...
* adadecode.cc: ...here.
* affinity.c: Moved to...
* affinity.cc: ...here.
* argv-lynxos178-raven-cert.c: Moved to...
* argv-lynxos178-raven-cert.cc: ...here.
* argv.c: Moved to...
* argv.cc: ...here.
* aux-io.c: Moved to...
* aux-io.cc: ...here.
* cio.c: Moved to...
* cio.cc: ...here.
* cstreams.c: Moved to...
* cstreams.cc: ...here.
* env.c: Moved to...
* env.cc: ...here.
* exit.c: Moved to...
* exit.cc: ...here.
* expect.c: Moved to...
* expect.cc: ...here.
* final.c: Moved to...
* final.cc: ...here.
* gcc-interface/cuintp.c: Moved to...
* gcc-interface/cuintp.cc: ...here.
* gcc-interface/decl.c: Moved to...
* gcc-interface/decl.cc: ...here.
* gcc-interface/misc.c: Moved to...
* gcc-interface/misc.cc: ...here.
* gcc-interface/targtyps.c: Moved to...
* gcc-interface/targtyps.cc: ...here.
* gcc-interface/trans.c: Moved to...
* gcc-interface/trans.cc: ...here.
* gcc-interface/utils.c: Moved to...
* gcc-interface/utils.cc: ...here.
* gcc-interface/utils2.c: Moved to...
* gcc-interface/utils2.cc: ...here.
* init.c: Moved to...
* init.cc: ...here.
* initialize.c: Moved to...
* initialize.cc: ...here.
* libgnarl/thread.c: Moved to...
* libgnarl/thread.cc: ...here.
* link.c: Moved to...
* link.cc: ...here.
* locales.c: Moved to...
* locales.cc: ...here.
* mkdir.c: Moved to...
* mkdir.cc: ...here.
* raise.c: Moved to...
* raise.cc: ...here.
* rtfinal.c: Moved to...
* rtfinal.cc: ...here.
* rtinit.c: Moved to...
* rtinit.cc: ...here.
* seh_init.c: Moved to...
* seh_init.cc: ...here.
* sigtramp-armdroid.c: Moved to...
* sigtramp-armdroid.cc: ...here.
* sigtramp-ios.c: Moved to...
* sigtramp-ios.cc: ...here.
* sigtramp-qnx.c: Moved to...
* sigtramp-qnx.cc: ...here.
* sigtramp-vxworks.c: Moved to...
* sigtramp-vxworks.cc: ...here.
* socket.c: Moved to...
* socket.cc: ...here.
* tracebak.c: Moved to...
* tracebak.cc: ...here.
* version.c: Moved to...
* version.cc: ...here.
* vx_stack_info.c: Moved to...
* vx_stack_info.cc: ...here.
gcc/ChangeLog:
* adjust-alignment.c: Moved to...
* adjust-alignment.cc: ...here.
* alias.c: Moved to...
* alias.cc: ...here.
* alloc-pool.c: Moved to...
* alloc-pool.cc: ...here.
* asan.c: Moved to...
* asan.cc: ...here.
* attribs.c: Moved to...
* attribs.cc: ...here.
* auto-inc-dec.c: Moved to...
* auto-inc-dec.cc: ...here.
* auto-profile.c: Moved to...
* auto-profile.cc: ...here.
* bb-reorder.c: Moved to...
* bb-reorder.cc: ...here.
* bitmap.c: Moved to...
* bitmap.cc: ...here.
* btfout.c: Moved to...
* btfout.cc: ...here.
* builtins.c: Moved to...
* builtins.cc: ...here.
* caller-save.c: Moved to...
* caller-save.cc: ...here.
* calls.c: Moved to...
* calls.cc: ...here.
* ccmp.c: Moved to...
* ccmp.cc: ...here.
* cfg.c: Moved to...
* cfg.cc: ...here.
* cfganal.c: Moved to...
* cfganal.cc: ...here.
* cfgbuild.c: Moved to...
* cfgbuild.cc: ...here.
* cfgcleanup.c: Moved to...
* cfgcleanup.cc: ...here.
* cfgexpand.c: Moved to...
* cfgexpand.cc: ...here.
* cfghooks.c: Moved to...
* cfghooks.cc: ...here.
* cfgloop.c: Moved to...
* cfgloop.cc: ...here.
* cfgloopanal.c: Moved to...
* cfgloopanal.cc: ...here.
* cfgloopmanip.c: Moved to...
* cfgloopmanip.cc: ...here.
* cfgrtl.c: Moved to...
* cfgrtl.cc: ...here.
* cgraph.c: Moved to...
* cgraph.cc: ...here.
* cgraphbuild.c: Moved to...
* cgraphbuild.cc: ...here.
* cgraphclones.c: Moved to...
* cgraphclones.cc: ...here.
* cgraphunit.c: Moved to...
* cgraphunit.cc: ...here.
* collect-utils.c: Moved to...
* collect-utils.cc: ...here.
* collect2-aix.c: Moved to...
* collect2-aix.cc: ...here.
* collect2.c: Moved to...
* collect2.cc: ...here.
* combine-stack-adj.c: Moved to...
* combine-stack-adj.cc: ...here.
* combine.c: Moved to...
* combine.cc: ...here.
* common/common-targhooks.c: Moved to...
* common/common-targhooks.cc: ...here.
* common/config/aarch64/aarch64-common.c: Moved to...
* common/config/aarch64/aarch64-common.cc: ...here.
* common/config/alpha/alpha-common.c: Moved to...
* common/config/alpha/alpha-common.cc: ...here.
* common/config/arc/arc-common.c: Moved to...
* common/config/arc/arc-common.cc: ...here.
* common/config/arm/arm-common.c: Moved to...
* common/config/arm/arm-common.cc: ...here.
* common/config/avr/avr-common.c: Moved to...
* common/config/avr/avr-common.cc: ...here.
* common/config/bfin/bfin-common.c: Moved to...
* common/config/bfin/bfin-common.cc: ...here.
* common/config/bpf/bpf-common.c: Moved to...
* common/config/bpf/bpf-common.cc: ...here.
* common/config/c6x/c6x-common.c: Moved to...
* common/config/c6x/c6x-common.cc: ...here.
* common/config/cr16/cr16-common.c: Moved to...
* common/config/cr16/cr16-common.cc: ...here.
* common/config/cris/cris-common.c: Moved to...
* common/config/cris/cris-common.cc: ...here.
* common/config/csky/csky-common.c: Moved to...
* common/config/csky/csky-common.cc: ...here.
* common/config/default-common.c: Moved to...
* common/config/default-common.cc: ...here.
* common/config/epiphany/epiphany-common.c: Moved to...
* common/config/epiphany/epiphany-common.cc: ...here.
* common/config/fr30/fr30-common.c: Moved to...
* common/config/fr30/fr30-common.cc: ...here.
* common/config/frv/frv-common.c: Moved to...
* common/config/frv/frv-common.cc: ...here.
* common/config/gcn/gcn-common.c: Moved to...
* common/config/gcn/gcn-common.cc: ...here.
* common/config/h8300/h8300-common.c: Moved to...
* common/config/h8300/h8300-common.cc: ...here.
* common/config/i386/i386-common.c: Moved to...
* common/config/i386/i386-common.cc: ...here.
* common/config/ia64/ia64-common.c: Moved to...
* common/config/ia64/ia64-common.cc: ...here.
* common/config/iq2000/iq2000-common.c: Moved to...
* common/config/iq2000/iq2000-common.cc: ...here.
* common/config/lm32/lm32-common.c: Moved to...
* common/config/lm32/lm32-common.cc: ...here.
* common/config/m32r/m32r-common.c: Moved to...
* common/config/m32r/m32r-common.cc: ...here.
* common/config/m68k/m68k-common.c: Moved to...
* common/config/m68k/m68k-common.cc: ...here.
* common/config/mcore/mcore-common.c: Moved to...
* common/config/mcore/mcore-common.cc: ...here.
* common/config/microblaze/microblaze-common.c: Moved to...
* common/config/microblaze/microblaze-common.cc: ...here.
* common/config/mips/mips-common.c: Moved to...
* common/config/mips/mips-common.cc: ...here.
* common/config/mmix/mmix-common.c: Moved to...
* common/config/mmix/mmix-common.cc: ...here.
* common/config/mn10300/mn10300-common.c: Moved to...
* common/config/mn10300/mn10300-common.cc: ...here.
* common/config/msp430/msp430-common.c: Moved to...
* common/config/msp430/msp430-common.cc: ...here.
* common/config/nds32/nds32-common.c: Moved to...
* common/config/nds32/nds32-common.cc: ...here.
* common/config/nios2/nios2-common.c: Moved to...
* common/config/nios2/nios2-common.cc: ...here.
* common/config/nvptx/nvptx-common.c: Moved to...
* common/config/nvptx/nvptx-common.cc: ...here.
* common/config/or1k/or1k-common.c: Moved to...
* common/config/or1k/or1k-common.cc: ...here.
* common/config/pa/pa-common.c: Moved to...
* common/config/pa/pa-common.cc: ...here.
* common/config/pdp11/pdp11-common.c: Moved to...
* common/config/pdp11/pdp11-common.cc: ...here.
* common/config/pru/pru-common.c: Moved to...
* common/config/pru/pru-common.cc: ...here.
* common/config/riscv/riscv-common.c: Moved to...
* common/config/riscv/riscv-common.cc: ...here.
* common/config/rs6000/rs6000-common.c: Moved to...
* common/config/rs6000/rs6000-common.cc: ...here.
* common/config/rx/rx-common.c: Moved to...
* common/config/rx/rx-common.cc: ...here.
* common/config/s390/s390-common.c: Moved to...
* common/config/s390/s390-common.cc: ...here.
* common/config/sh/sh-common.c: Moved to...
* common/config/sh/sh-common.cc: ...here.
* common/config/sparc/sparc-common.c: Moved to...
* common/config/sparc/sparc-common.cc: ...here.
* common/config/tilegx/tilegx-common.c: Moved to...
* common/config/tilegx/tilegx-common.cc: ...here.
* common/config/tilepro/tilepro-common.c: Moved to...
* common/config/tilepro/tilepro-common.cc: ...here.
* common/config/v850/v850-common.c: Moved to...
* common/config/v850/v850-common.cc: ...here.
* common/config/vax/vax-common.c: Moved to...
* common/config/vax/vax-common.cc: ...here.
* common/config/visium/visium-common.c: Moved to...
* common/config/visium/visium-common.cc: ...here.
* common/config/xstormy16/xstormy16-common.c: Moved to...
* common/config/xstormy16/xstormy16-common.cc: ...here.
* common/config/xtensa/xtensa-common.c: Moved to...
* common/config/xtensa/xtensa-common.cc: ...here.
* compare-elim.c: Moved to...
* compare-elim.cc: ...here.
* config/aarch64/aarch64-bti-insert.c: Moved to...
* config/aarch64/aarch64-bti-insert.cc: ...here.
* config/aarch64/aarch64-builtins.c: Moved to...
* config/aarch64/aarch64-builtins.cc: ...here.
* config/aarch64/aarch64-c.c: Moved to...
* config/aarch64/aarch64-c.cc: ...here.
* config/aarch64/aarch64-d.c: Moved to...
* config/aarch64/aarch64-d.cc: ...here.
* config/aarch64/aarch64.c: Moved to...
* config/aarch64/aarch64.cc: ...here.
* config/aarch64/cortex-a57-fma-steering.c: Moved to...
* config/aarch64/cortex-a57-fma-steering.cc: ...here.
* config/aarch64/driver-aarch64.c: Moved to...
* config/aarch64/driver-aarch64.cc: ...here.
* config/aarch64/falkor-tag-collision-avoidance.c: Moved to...
* config/aarch64/falkor-tag-collision-avoidance.cc: ...here.
* config/aarch64/host-aarch64-darwin.c: Moved to...
* config/aarch64/host-aarch64-darwin.cc: ...here.
* config/alpha/alpha.c: Moved to...
* config/alpha/alpha.cc: ...here.
* config/alpha/driver-alpha.c: Moved to...
* config/alpha/driver-alpha.cc: ...here.
* config/arc/arc-c.c: Moved to...
* config/arc/arc-c.cc: ...here.
* config/arc/arc.c: Moved to...
* config/arc/arc.cc: ...here.
* config/arc/driver-arc.c: Moved to...
* config/arc/driver-arc.cc: ...here.
* config/arm/aarch-common.c: Moved to...
* config/arm/aarch-common.cc: ...here.
* config/arm/arm-builtins.c: Moved to...
* config/arm/arm-builtins.cc: ...here.
* config/arm/arm-c.c: Moved to...
* config/arm/arm-c.cc: ...here.
* config/arm/arm-d.c: Moved to...
* config/arm/arm-d.cc: ...here.
* config/arm/arm.c: Moved to...
* config/arm/arm.cc: ...here.
* config/arm/driver-arm.c: Moved to...
* config/arm/driver-arm.cc: ...here.
* config/avr/avr-c.c: Moved to...
* config/avr/avr-c.cc: ...here.
* config/avr/avr-devices.c: Moved to...
* config/avr/avr-devices.cc: ...here.
* config/avr/avr-log.c: Moved to...
* config/avr/avr-log.cc: ...here.
* config/avr/avr.c: Moved to...
* config/avr/avr.cc: ...here.
* config/avr/driver-avr.c: Moved to...
* config/avr/driver-avr.cc: ...here.
* config/avr/gen-avr-mmcu-specs.c: Moved to...
* config/avr/gen-avr-mmcu-specs.cc: ...here.
* config/avr/gen-avr-mmcu-texi.c: Moved to...
* config/avr/gen-avr-mmcu-texi.cc: ...here.
* config/bfin/bfin.c: Moved to...
* config/bfin/bfin.cc: ...here.
* config/bpf/bpf.c: Moved to...
* config/bpf/bpf.cc: ...here.
* config/bpf/coreout.c: Moved to...
* config/bpf/coreout.cc: ...here.
* config/c6x/c6x.c: Moved to...
* config/c6x/c6x.cc: ...here.
* config/cr16/cr16.c: Moved to...
* config/cr16/cr16.cc: ...here.
* config/cris/cris.c: Moved to...
* config/cris/cris.cc: ...here.
* config/csky/csky.c: Moved to...
* config/csky/csky.cc: ...here.
* config/darwin-c.c: Moved to...
* config/darwin-c.cc: ...here.
* config/darwin-d.c: Moved to...
* config/darwin-d.cc: ...here.
* config/darwin-driver.c: Moved to...
* config/darwin-driver.cc: ...here.
* config/darwin-f.c: Moved to...
* config/darwin-f.cc: ...here.
* config/darwin.c: Moved to...
* config/darwin.cc: ...here.
* config/default-c.c: Moved to...
* config/default-c.cc: ...here.
* config/default-d.c: Moved to...
* config/default-d.cc: ...here.
* config/dragonfly-d.c: Moved to...
* config/dragonfly-d.cc: ...here.
* config/epiphany/epiphany.c: Moved to...
* config/epiphany/epiphany.cc: ...here.
* config/epiphany/mode-switch-use.c: Moved to...
* config/epiphany/mode-switch-use.cc: ...here.
* config/epiphany/resolve-sw-modes.c: Moved to...
* config/epiphany/resolve-sw-modes.cc: ...here.
* config/fr30/fr30.c: Moved to...
* config/fr30/fr30.cc: ...here.
* config/freebsd-d.c: Moved to...
* config/freebsd-d.cc: ...here.
* config/frv/frv.c: Moved to...
* config/frv/frv.cc: ...here.
* config/ft32/ft32.c: Moved to...
* config/ft32/ft32.cc: ...here.
* config/gcn/driver-gcn.c: Moved to...
* config/gcn/driver-gcn.cc: ...here.
* config/gcn/gcn-run.c: Moved to...
* config/gcn/gcn-run.cc: ...here.
* config/gcn/gcn-tree.c: Moved to...
* config/gcn/gcn-tree.cc: ...here.
* config/gcn/gcn.c: Moved to...
* config/gcn/gcn.cc: ...here.
* config/gcn/mkoffload.c: Moved to...
* config/gcn/mkoffload.cc: ...here.
* config/glibc-c.c: Moved to...
* config/glibc-c.cc: ...here.
* config/glibc-d.c: Moved to...
* config/glibc-d.cc: ...here.
* config/h8300/h8300.c: Moved to...
* config/h8300/h8300.cc: ...here.
* config/host-darwin.c: Moved to...
* config/host-darwin.cc: ...here.
* config/host-hpux.c: Moved to...
* config/host-hpux.cc: ...here.
* config/host-linux.c: Moved to...
* config/host-linux.cc: ...here.
* config/host-netbsd.c: Moved to...
* config/host-netbsd.cc: ...here.
* config/host-openbsd.c: Moved to...
* config/host-openbsd.cc: ...here.
* config/host-solaris.c: Moved to...
* config/host-solaris.cc: ...here.
* config/i386/djgpp.c: Moved to...
* config/i386/djgpp.cc: ...here.
* config/i386/driver-i386.c: Moved to...
* config/i386/driver-i386.cc: ...here.
* config/i386/driver-mingw32.c: Moved to...
* config/i386/driver-mingw32.cc: ...here.
* config/i386/gnu-property.c: Moved to...
* config/i386/gnu-property.cc: ...here.
* config/i386/host-cygwin.c: Moved to...
* config/i386/host-cygwin.cc: ...here.
* config/i386/host-i386-darwin.c: Moved to...
* config/i386/host-i386-darwin.cc: ...here.
* config/i386/host-mingw32.c: Moved to...
* config/i386/host-mingw32.cc: ...here.
* config/i386/i386-builtins.c: Moved to...
* config/i386/i386-builtins.cc: ...here.
* config/i386/i386-c.c: Moved to...
* config/i386/i386-c.cc: ...here.
* config/i386/i386-d.c: Moved to...
* config/i386/i386-d.cc: ...here.
* config/i386/i386-expand.c: Moved to...
* config/i386/i386-expand.cc: ...here.
* config/i386/i386-features.c: Moved to...
* config/i386/i386-features.cc: ...here.
* config/i386/i386-options.c: Moved to...
* config/i386/i386-options.cc: ...here.
* config/i386/i386.c: Moved to...
* config/i386/i386.cc: ...here.
* config/i386/intelmic-mkoffload.c: Moved to...
* config/i386/intelmic-mkoffload.cc: ...here.
* config/i386/msformat-c.c: Moved to...
* config/i386/msformat-c.cc: ...here.
* config/i386/winnt-cxx.c: Moved to...
* config/i386/winnt-cxx.cc: ...here.
* config/i386/winnt-d.c: Moved to...
* config/i386/winnt-d.cc: ...here.
* config/i386/winnt-stubs.c: Moved to...
* config/i386/winnt-stubs.cc: ...here.
* config/i386/winnt.c: Moved to...
* config/i386/winnt.cc: ...here.
* config/i386/x86-tune-sched-atom.c: Moved to...
* config/i386/x86-tune-sched-atom.cc: ...here.
* config/i386/x86-tune-sched-bd.c: Moved to...
* config/i386/x86-tune-sched-bd.cc: ...here.
* config/i386/x86-tune-sched-core.c: Moved to...
* config/i386/x86-tune-sched-core.cc: ...here.
* config/i386/x86-tune-sched.c: Moved to...
* config/i386/x86-tune-sched.cc: ...here.
* config/ia64/ia64-c.c: Moved to...
* config/ia64/ia64-c.cc: ...here.
* config/ia64/ia64.c: Moved to...
* config/ia64/ia64.cc: ...here.
* config/iq2000/iq2000.c: Moved to...
* config/iq2000/iq2000.cc: ...here.
* config/linux.c: Moved to...
* config/linux.cc: ...here.
* config/lm32/lm32.c: Moved to...
* config/lm32/lm32.cc: ...here.
* config/m32c/m32c-pragma.c: Moved to...
* config/m32c/m32c-pragma.cc: ...here.
* config/m32c/m32c.c: Moved to...
* config/m32c/m32c.cc: ...here.
* config/m32r/m32r.c: Moved to...
* config/m32r/m32r.cc: ...here.
* config/m68k/m68k.c: Moved to...
* config/m68k/m68k.cc: ...here.
* config/mcore/mcore.c: Moved to...
* config/mcore/mcore.cc: ...here.
* config/microblaze/microblaze-c.c: Moved to...
* config/microblaze/microblaze-c.cc: ...here.
* config/microblaze/microblaze.c: Moved to...
* config/microblaze/microblaze.cc: ...here.
* config/mips/driver-native.c: Moved to...
* config/mips/driver-native.cc: ...here.
* config/mips/frame-header-opt.c: Moved to...
* config/mips/frame-header-opt.cc: ...here.
* config/mips/mips-d.c: Moved to...
* config/mips/mips-d.cc: ...here.
* config/mips/mips.c: Moved to...
* config/mips/mips.cc: ...here.
* config/mmix/mmix.c: Moved to...
* config/mmix/mmix.cc: ...here.
* config/mn10300/mn10300.c: Moved to...
* config/mn10300/mn10300.cc: ...here.
* config/moxie/moxie.c: Moved to...
* config/moxie/moxie.cc: ...here.
* config/msp430/driver-msp430.c: Moved to...
* config/msp430/driver-msp430.cc: ...here.
* config/msp430/msp430-c.c: Moved to...
* config/msp430/msp430-c.cc: ...here.
* config/msp430/msp430-devices.c: Moved to...
* config/msp430/msp430-devices.cc: ...here.
* config/msp430/msp430.c: Moved to...
* config/msp430/msp430.cc: ...here.
* config/nds32/nds32-cost.c: Moved to...
* config/nds32/nds32-cost.cc: ...here.
* config/nds32/nds32-fp-as-gp.c: Moved to...
* config/nds32/nds32-fp-as-gp.cc: ...here.
* config/nds32/nds32-intrinsic.c: Moved to...
* config/nds32/nds32-intrinsic.cc: ...here.
* config/nds32/nds32-isr.c: Moved to...
* config/nds32/nds32-isr.cc: ...here.
* config/nds32/nds32-md-auxiliary.c: Moved to...
* config/nds32/nds32-md-auxiliary.cc: ...here.
* config/nds32/nds32-memory-manipulation.c: Moved to...
* config/nds32/nds32-memory-manipulation.cc: ...here.
* config/nds32/nds32-pipelines-auxiliary.c: Moved to...
* config/nds32/nds32-pipelines-auxiliary.cc: ...here.
* config/nds32/nds32-predicates.c: Moved to...
* config/nds32/nds32-predicates.cc: ...here.
* config/nds32/nds32-relax-opt.c: Moved to...
* config/nds32/nds32-relax-opt.cc: ...here.
* config/nds32/nds32-utils.c: Moved to...
* config/nds32/nds32-utils.cc: ...here.
* config/nds32/nds32.c: Moved to...
* config/nds32/nds32.cc: ...here.
* config/netbsd-d.c: Moved to...
* config/netbsd-d.cc: ...here.
* config/netbsd.c: Moved to...
* config/netbsd.cc: ...here.
* config/nios2/nios2.c: Moved to...
* config/nios2/nios2.cc: ...here.
* config/nvptx/mkoffload.c: Moved to...
* config/nvptx/mkoffload.cc: ...here.
* config/nvptx/nvptx-c.c: Moved to...
* config/nvptx/nvptx-c.cc: ...here.
* config/nvptx/nvptx.c: Moved to...
* config/nvptx/nvptx.cc: ...here.
* config/openbsd-d.c: Moved to...
* config/openbsd-d.cc: ...here.
* config/or1k/or1k.c: Moved to...
* config/or1k/or1k.cc: ...here.
* config/pa/pa-d.c: Moved to...
* config/pa/pa-d.cc: ...here.
* config/pa/pa.c: Moved to...
* config/pa/pa.cc: ...here.
* config/pdp11/pdp11.c: Moved to...
* config/pdp11/pdp11.cc: ...here.
* config/pru/pru-passes.c: Moved to...
* config/pru/pru-passes.cc: ...here.
* config/pru/pru-pragma.c: Moved to...
* config/pru/pru-pragma.cc: ...here.
* config/pru/pru.c: Moved to...
* config/pru/pru.cc: ...here.
* config/riscv/riscv-builtins.c: Moved to...
* config/riscv/riscv-builtins.cc: ...here.
* config/riscv/riscv-c.c: Moved to...
* config/riscv/riscv-c.cc: ...here.
* config/riscv/riscv-d.c: Moved to...
* config/riscv/riscv-d.cc: ...here.
* config/riscv/riscv-shorten-memrefs.c: Moved to...
* config/riscv/riscv-shorten-memrefs.cc: ...here.
* config/riscv/riscv-sr.c: Moved to...
* config/riscv/riscv-sr.cc: ...here.
* config/riscv/riscv.c: Moved to...
* config/riscv/riscv.cc: ...here.
* config/rl78/rl78-c.c: Moved to...
* config/rl78/rl78-c.cc: ...here.
* config/rl78/rl78.c: Moved to...
* config/rl78/rl78.cc: ...here.
* config/rs6000/driver-rs6000.c: Moved to...
* config/rs6000/driver-rs6000.cc: ...here.
* config/rs6000/host-darwin.c: Moved to...
* config/rs6000/host-darwin.cc: ...here.
* config/rs6000/host-ppc64-darwin.c: Moved to...
* config/rs6000/host-ppc64-darwin.cc: ...here.
* config/rs6000/rbtree.c: Moved to...
* config/rs6000/rbtree.cc: ...here.
* config/rs6000/rs6000-c.c: Moved to...
* config/rs6000/rs6000-c.cc: ...here.
* config/rs6000/rs6000-call.c: Moved to...
* config/rs6000/rs6000-call.cc: ...here.
* config/rs6000/rs6000-d.c: Moved to...
* config/rs6000/rs6000-d.cc: ...here.
* config/rs6000/rs6000-gen-builtins.c: Moved to...
* config/rs6000/rs6000-gen-builtins.cc: ...here.
* config/rs6000/rs6000-linux.c: Moved to...
* config/rs6000/rs6000-linux.cc: ...here.
* config/rs6000/rs6000-logue.c: Moved to...
* config/rs6000/rs6000-logue.cc: ...here.
* config/rs6000/rs6000-p8swap.c: Moved to...
* config/rs6000/rs6000-p8swap.cc: ...here.
* config/rs6000/rs6000-pcrel-opt.c: Moved to...
* config/rs6000/rs6000-pcrel-opt.cc: ...here.
* config/rs6000/rs6000-string.c: Moved to...
* config/rs6000/rs6000-string.cc: ...here.
* config/rs6000/rs6000.c: Moved to...
* config/rs6000/rs6000.cc: ...here.
* config/rx/rx.c: Moved to...
* config/rx/rx.cc: ...here.
* config/s390/driver-native.c: Moved to...
* config/s390/driver-native.cc: ...here.
* config/s390/s390-c.c: Moved to...
* config/s390/s390-c.cc: ...here.
* config/s390/s390-d.c: Moved to...
* config/s390/s390-d.cc: ...here.
* config/s390/s390.c: Moved to...
* config/s390/s390.cc: ...here.
* config/sh/divtab-sh4-300.c: Moved to...
* config/sh/divtab-sh4-300.cc: ...here.
* config/sh/divtab-sh4.c: Moved to...
* config/sh/divtab-sh4.cc: ...here.
* config/sh/divtab.c: Moved to...
* config/sh/divtab.cc: ...here.
* config/sh/sh-c.c: Moved to...
* config/sh/sh-c.cc: ...here.
* config/sh/sh.c: Moved to...
* config/sh/sh.cc: ...here.
* config/sol2-c.c: Moved to...
* config/sol2-c.cc: ...here.
* config/sol2-cxx.c: Moved to...
* config/sol2-cxx.cc: ...here.
* config/sol2-d.c: Moved to...
* config/sol2-d.cc: ...here.
* config/sol2-stubs.c: Moved to...
* config/sol2-stubs.cc: ...here.
* config/sol2.c: Moved to...
* config/sol2.cc: ...here.
* config/sparc/driver-sparc.c: Moved to...
* config/sparc/driver-sparc.cc: ...here.
* config/sparc/sparc-c.c: Moved to...
* config/sparc/sparc-c.cc: ...here.
* config/sparc/sparc-d.c: Moved to...
* config/sparc/sparc-d.cc: ...here.
* config/sparc/sparc.c: Moved to...
* config/sparc/sparc.cc: ...here.
* config/stormy16/stormy16.c: Moved to...
* config/stormy16/stormy16.cc: ...here.
* config/tilegx/mul-tables.c: Moved to...
* config/tilegx/mul-tables.cc: ...here.
* config/tilegx/tilegx-c.c: Moved to...
* config/tilegx/tilegx-c.cc: ...here.
* config/tilegx/tilegx.c: Moved to...
* config/tilegx/tilegx.cc: ...here.
* config/tilepro/mul-tables.c: Moved to...
* config/tilepro/mul-tables.cc: ...here.
* config/tilepro/tilepro-c.c: Moved to...
* config/tilepro/tilepro-c.cc: ...here.
* config/tilepro/tilepro.c: Moved to...
* config/tilepro/tilepro.cc: ...here.
* config/v850/v850-c.c: Moved to...
* config/v850/v850-c.cc: ...here.
* config/v850/v850.c: Moved to...
* config/v850/v850.cc: ...here.
* config/vax/vax.c: Moved to...
* config/vax/vax.cc: ...here.
* config/visium/visium.c: Moved to...
* config/visium/visium.cc: ...here.
* config/vms/vms-c.c: Moved to...
* config/vms/vms-c.cc: ...here.
* config/vms/vms-f.c: Moved to...
* config/vms/vms-f.cc: ...here.
* config/vms/vms.c: Moved to...
* config/vms/vms.cc: ...here.
* config/vxworks-c.c: Moved to...
* config/vxworks-c.cc: ...here.
* config/vxworks.c: Moved to...
* config/vxworks.cc: ...here.
* config/winnt-c.c: Moved to...
* config/winnt-c.cc: ...here.
* config/xtensa/xtensa.c: Moved to...
* config/xtensa/xtensa.cc: ...here.
* context.c: Moved to...
* context.cc: ...here.
* convert.c: Moved to...
* convert.cc: ...here.
* coverage.c: Moved to...
* coverage.cc: ...here.
* cppbuiltin.c: Moved to...
* cppbuiltin.cc: ...here.
* cppdefault.c: Moved to...
* cppdefault.cc: ...here.
* cprop.c: Moved to...
* cprop.cc: ...here.
* cse.c: Moved to...
* cse.cc: ...here.
* cselib.c: Moved to...
* cselib.cc: ...here.
* ctfc.c: Moved to...
* ctfc.cc: ...here.
* ctfout.c: Moved to...
* ctfout.cc: ...here.
* data-streamer-in.c: Moved to...
* data-streamer-in.cc: ...here.
* data-streamer-out.c: Moved to...
* data-streamer-out.cc: ...here.
* data-streamer.c: Moved to...
* data-streamer.cc: ...here.
* dbgcnt.c: Moved to...
* dbgcnt.cc: ...here.
* dbxout.c: Moved to...
* dbxout.cc: ...here.
* dce.c: Moved to...
* dce.cc: ...here.
* ddg.c: Moved to...
* ddg.cc: ...here.
* debug.c: Moved to...
* debug.cc: ...here.
* df-core.c: Moved to...
* df-core.cc: ...here.
* df-problems.c: Moved to...
* df-problems.cc: ...here.
* df-scan.c: Moved to...
* df-scan.cc: ...here.
* dfp.c: Moved to...
* dfp.cc: ...here.
* diagnostic-color.c: Moved to...
* diagnostic-color.cc: ...here.
* diagnostic-show-locus.c: Moved to...
* diagnostic-show-locus.cc: ...here.
* diagnostic-spec.c: Moved to...
* diagnostic-spec.cc: ...here.
* diagnostic.c: Moved to...
* diagnostic.cc: ...here.
* dojump.c: Moved to...
* dojump.cc: ...here.
* dominance.c: Moved to...
* dominance.cc: ...here.
* domwalk.c: Moved to...
* domwalk.cc: ...here.
* double-int.c: Moved to...
* double-int.cc: ...here.
* dse.c: Moved to...
* dse.cc: ...here.
* dumpfile.c: Moved to...
* dumpfile.cc: ...here.
* dwarf2asm.c: Moved to...
* dwarf2asm.cc: ...here.
* dwarf2cfi.c: Moved to...
* dwarf2cfi.cc: ...here.
* dwarf2ctf.c: Moved to...
* dwarf2ctf.cc: ...here.
* dwarf2out.c: Moved to...
* dwarf2out.cc: ...here.
* early-remat.c: Moved to...
* early-remat.cc: ...here.
* edit-context.c: Moved to...
* edit-context.cc: ...here.
* emit-rtl.c: Moved to...
* emit-rtl.cc: ...here.
* errors.c: Moved to...
* errors.cc: ...here.
* et-forest.c: Moved to...
* et-forest.cc: ...here.
* except.c: Moved to...
* except.cc: ...here.
* explow.c: Moved to...
* explow.cc: ...here.
* expmed.c: Moved to...
* expmed.cc: ...here.
* expr.c: Moved to...
* expr.cc: ...here.
* fibonacci_heap.c: Moved to...
* fibonacci_heap.cc: ...here.
* file-find.c: Moved to...
* file-find.cc: ...here.
* file-prefix-map.c: Moved to...
* file-prefix-map.cc: ...here.
* final.c: Moved to...
* final.cc: ...here.
* fixed-value.c: Moved to...
* fixed-value.cc: ...here.
* fold-const-call.c: Moved to...
* fold-const-call.cc: ...here.
* fold-const.c: Moved to...
* fold-const.cc: ...here.
* fp-test.c: Moved to...
* fp-test.cc: ...here.
* function-tests.c: Moved to...
* function-tests.cc: ...here.
* function.c: Moved to...
* function.cc: ...here.
* fwprop.c: Moved to...
* fwprop.cc: ...here.
* gcc-ar.c: Moved to...
* gcc-ar.cc: ...here.
* gcc-main.c: Moved to...
* gcc-main.cc: ...here.
* gcc-rich-location.c: Moved to...
* gcc-rich-location.cc: ...here.
* gcc.c: Moved to...
* gcc.cc: ...here.
* gcov-dump.c: Moved to...
* gcov-dump.cc: ...here.
* gcov-io.c: Moved to...
* gcov-io.cc: ...here.
* gcov-tool.c: Moved to...
* gcov-tool.cc: ...here.
* gcov.c: Moved to...
* gcov.cc: ...here.
* gcse-common.c: Moved to...
* gcse-common.cc: ...here.
* gcse.c: Moved to...
* gcse.cc: ...here.
* genattr-common.c: Moved to...
* genattr-common.cc: ...here.
* genattr.c: Moved to...
* genattr.cc: ...here.
* genattrtab.c: Moved to...
* genattrtab.cc: ...here.
* genautomata.c: Moved to...
* genautomata.cc: ...here.
* gencfn-macros.c: Moved to...
* gencfn-macros.cc: ...here.
* gencheck.c: Moved to...
* gencheck.cc: ...here.
* genchecksum.c: Moved to...
* genchecksum.cc: ...here.
* gencodes.c: Moved to...
* gencodes.cc: ...here.
* genconditions.c: Moved to...
* genconditions.cc: ...here.
* genconfig.c: Moved to...
* genconfig.cc: ...here.
* genconstants.c: Moved to...
* genconstants.cc: ...here.
* genemit.c: Moved to...
* genemit.cc: ...here.
* genenums.c: Moved to...
* genenums.cc: ...here.
* generic-match-head.c: Moved to...
* generic-match-head.cc: ...here.
* genextract.c: Moved to...
* genextract.cc: ...here.
* genflags.c: Moved to...
* genflags.cc: ...here.
* gengenrtl.c: Moved to...
* gengenrtl.cc: ...here.
* gengtype-parse.c: Moved to...
* gengtype-parse.cc: ...here.
* gengtype-state.c: Moved to...
* gengtype-state.cc: ...here.
* gengtype.c: Moved to...
* gengtype.cc: ...here.
* genhooks.c: Moved to...
* genhooks.cc: ...here.
* genmatch.c: Moved to...
* genmatch.cc: ...here.
* genmddeps.c: Moved to...
* genmddeps.cc: ...here.
* genmddump.c: Moved to...
* genmddump.cc: ...here.
* genmodes.c: Moved to...
* genmodes.cc: ...here.
* genopinit.c: Moved to...
* genopinit.cc: ...here.
* genoutput.c: Moved to...
* genoutput.cc: ...here.
* genpeep.c: Moved to...
* genpeep.cc: ...here.
* genpreds.c: Moved to...
* genpreds.cc: ...here.
* genrecog.c: Moved to...
* genrecog.cc: ...here.
* gensupport.c: Moved to...
* gensupport.cc: ...here.
* gentarget-def.c: Moved to...
* gentarget-def.cc: ...here.
* genversion.c: Moved to...
* genversion.cc: ...here.
* ggc-common.c: Moved to...
* ggc-common.cc: ...here.
* ggc-none.c: Moved to...
* ggc-none.cc: ...here.
* ggc-page.c: Moved to...
* ggc-page.cc: ...here.
* ggc-tests.c: Moved to...
* ggc-tests.cc: ...here.
* gimple-builder.c: Moved to...
* gimple-builder.cc: ...here.
* gimple-expr.c: Moved to...
* gimple-expr.cc: ...here.
* gimple-fold.c: Moved to...
* gimple-fold.cc: ...here.
* gimple-iterator.c: Moved to...
* gimple-iterator.cc: ...here.
* gimple-laddress.c: Moved to...
* gimple-laddress.cc: ...here.
* gimple-loop-jam.c: Moved to...
* gimple-loop-jam.cc: ...here.
* gimple-low.c: Moved to...
* gimple-low.cc: ...here.
* gimple-match-head.c: Moved to...
* gimple-match-head.cc: ...here.
* gimple-pretty-print.c: Moved to...
* gimple-pretty-print.cc: ...here.
* gimple-ssa-backprop.c: Moved to...
* gimple-ssa-backprop.cc: ...here.
* gimple-ssa-evrp-analyze.c: Moved to...
* gimple-ssa-evrp-analyze.cc: ...here.
* gimple-ssa-evrp.c: Moved to...
* gimple-ssa-evrp.cc: ...here.
* gimple-ssa-isolate-paths.c: Moved to...
* gimple-ssa-isolate-paths.cc: ...here.
* gimple-ssa-nonnull-compare.c: Moved to...
* gimple-ssa-nonnull-compare.cc: ...here.
* gimple-ssa-split-paths.c: Moved to...
* gimple-ssa-split-paths.cc: ...here.
* gimple-ssa-sprintf.c: Moved to...
* gimple-ssa-sprintf.cc: ...here.
* gimple-ssa-store-merging.c: Moved to...
* gimple-ssa-store-merging.cc: ...here.
* gimple-ssa-strength-reduction.c: Moved to...
* gimple-ssa-strength-reduction.cc: ...here.
* gimple-ssa-warn-alloca.c: Moved to...
* gimple-ssa-warn-alloca.cc: ...here.
* gimple-ssa-warn-restrict.c: Moved to...
* gimple-ssa-warn-restrict.cc: ...here.
* gimple-streamer-in.c: Moved to...
* gimple-streamer-in.cc: ...here.
* gimple-streamer-out.c: Moved to...
* gimple-streamer-out.cc: ...here.
* gimple-walk.c: Moved to...
* gimple-walk.cc: ...here.
* gimple-warn-recursion.c: Moved to...
* gimple-warn-recursion.cc: ...here.
* gimple.c: Moved to...
* gimple.cc: ...here.
* gimplify-me.c: Moved to...
* gimplify-me.cc: ...here.
* gimplify.c: Moved to...
* gimplify.cc: ...here.
* godump.c: Moved to...
* godump.cc: ...here.
* graph.c: Moved to...
* graph.cc: ...here.
* graphds.c: Moved to...
* graphds.cc: ...here.
* graphite-dependences.c: Moved to...
* graphite-dependences.cc: ...here.
* graphite-isl-ast-to-gimple.c: Moved to...
* graphite-isl-ast-to-gimple.cc: ...here.
* graphite-optimize-isl.c: Moved to...
* graphite-optimize-isl.cc: ...here.
* graphite-poly.c: Moved to...
* graphite-poly.cc: ...here.
* graphite-scop-detection.c: Moved to...
* graphite-scop-detection.cc: ...here.
* graphite-sese-to-poly.c: Moved to...
* graphite-sese-to-poly.cc: ...here.
* graphite.c: Moved to...
* graphite.cc: ...here.
* haifa-sched.c: Moved to...
* haifa-sched.cc: ...here.
* hash-map-tests.c: Moved to...
* hash-map-tests.cc: ...here.
* hash-set-tests.c: Moved to...
* hash-set-tests.cc: ...here.
* hash-table.c: Moved to...
* hash-table.cc: ...here.
* hooks.c: Moved to...
* hooks.cc: ...here.
* host-default.c: Moved to...
* host-default.cc: ...here.
* hw-doloop.c: Moved to...
* hw-doloop.cc: ...here.
* hwint.c: Moved to...
* hwint.cc: ...here.
* ifcvt.c: Moved to...
* ifcvt.cc: ...here.
* inchash.c: Moved to...
* inchash.cc: ...here.
* incpath.c: Moved to...
* incpath.cc: ...here.
* init-regs.c: Moved to...
* init-regs.cc: ...here.
* input.c: Moved to...
* input.cc: ...here.
* internal-fn.c: Moved to...
* internal-fn.cc: ...here.
* intl.c: Moved to...
* intl.cc: ...here.
* ipa-comdats.c: Moved to...
* ipa-comdats.cc: ...here.
* ipa-cp.c: Moved to...
* ipa-cp.cc: ...here.
* ipa-devirt.c: Moved to...
* ipa-devirt.cc: ...here.
* ipa-fnsummary.c: Moved to...
* ipa-fnsummary.cc: ...here.
* ipa-icf-gimple.c: Moved to...
* ipa-icf-gimple.cc: ...here.
* ipa-icf.c: Moved to...
* ipa-icf.cc: ...here.
* ipa-inline-analysis.c: Moved to...
* ipa-inline-analysis.cc: ...here.
* ipa-inline-transform.c: Moved to...
* ipa-inline-transform.cc: ...here.
* ipa-inline.c: Moved to...
* ipa-inline.cc: ...here.
* ipa-modref-tree.c: Moved to...
* ipa-modref-tree.cc: ...here.
* ipa-modref.c: Moved to...
* ipa-modref.cc: ...here.
* ipa-param-manipulation.c: Moved to...
* ipa-param-manipulation.cc: ...here.
* ipa-polymorphic-call.c: Moved to...
* ipa-polymorphic-call.cc: ...here.
* ipa-predicate.c: Moved to...
* ipa-predicate.cc: ...here.
* ipa-profile.c: Moved to...
* ipa-profile.cc: ...here.
* ipa-prop.c: Moved to...
* ipa-prop.cc: ...here.
* ipa-pure-const.c: Moved to...
* ipa-pure-const.cc: ...here.
* ipa-ref.c: Moved to...
* ipa-ref.cc: ...here.
* ipa-reference.c: Moved to...
* ipa-reference.cc: ...here.
* ipa-split.c: Moved to...
* ipa-split.cc: ...here.
* ipa-sra.c: Moved to...
* ipa-sra.cc: ...here.
* ipa-utils.c: Moved to...
* ipa-utils.cc: ...here.
* ipa-visibility.c: Moved to...
* ipa-visibility.cc: ...here.
* ipa.c: Moved to...
* ipa.cc: ...here.
* ira-build.c: Moved to...
* ira-build.cc: ...here.
* ira-color.c: Moved to...
* ira-color.cc: ...here.
* ira-conflicts.c: Moved to...
* ira-conflicts.cc: ...here.
* ira-costs.c: Moved to...
* ira-costs.cc: ...here.
* ira-emit.c: Moved to...
* ira-emit.cc: ...here.
* ira-lives.c: Moved to...
* ira-lives.cc: ...here.
* ira.c: Moved to...
* ira.cc: ...here.
* jump.c: Moved to...
* jump.cc: ...here.
* langhooks.c: Moved to...
* langhooks.cc: ...here.
* lcm.c: Moved to...
* lcm.cc: ...here.
* lists.c: Moved to...
* lists.cc: ...here.
* loop-doloop.c: Moved to...
* loop-doloop.cc: ...here.
* loop-init.c: Moved to...
* loop-init.cc: ...here.
* loop-invariant.c: Moved to...
* loop-invariant.cc: ...here.
* loop-iv.c: Moved to...
* loop-iv.cc: ...here.
* loop-unroll.c: Moved to...
* loop-unroll.cc: ...here.
* lower-subreg.c: Moved to...
* lower-subreg.cc: ...here.
* lra-assigns.c: Moved to...
* lra-assigns.cc: ...here.
* lra-coalesce.c: Moved to...
* lra-coalesce.cc: ...here.
* lra-constraints.c: Moved to...
* lra-constraints.cc: ...here.
* lra-eliminations.c: Moved to...
* lra-eliminations.cc: ...here.
* lra-lives.c: Moved to...
* lra-lives.cc: ...here.
* lra-remat.c: Moved to...
* lra-remat.cc: ...here.
* lra-spills.c: Moved to...
* lra-spills.cc: ...here.
* lra.c: Moved to...
* lra.cc: ...here.
* lto-cgraph.c: Moved to...
* lto-cgraph.cc: ...here.
* lto-compress.c: Moved to...
* lto-compress.cc: ...here.
* lto-opts.c: Moved to...
* lto-opts.cc: ...here.
* lto-section-in.c: Moved to...
* lto-section-in.cc: ...here.
* lto-section-out.c: Moved to...
* lto-section-out.cc: ...here.
* lto-streamer-in.c: Moved to...
* lto-streamer-in.cc: ...here.
* lto-streamer-out.c: Moved to...
* lto-streamer-out.cc: ...here.
* lto-streamer.c: Moved to...
* lto-streamer.cc: ...here.
* lto-wrapper.c: Moved to...
* lto-wrapper.cc: ...here.
* main.c: Moved to...
* main.cc: ...here.
* mcf.c: Moved to...
* mcf.cc: ...here.
* mode-switching.c: Moved to...
* mode-switching.cc: ...here.
* modulo-sched.c: Moved to...
* modulo-sched.cc: ...here.
* multiple_target.c: Moved to...
* multiple_target.cc: ...here.
* omp-expand.c: Moved to...
* omp-expand.cc: ...here.
* omp-general.c: Moved to...
* omp-general.cc: ...here.
* omp-low.c: Moved to...
* omp-low.cc: ...here.
* omp-offload.c: Moved to...
* omp-offload.cc: ...here.
* omp-simd-clone.c: Moved to...
* omp-simd-clone.cc: ...here.
* opt-suggestions.c: Moved to...
* opt-suggestions.cc: ...here.
* optabs-libfuncs.c: Moved to...
* optabs-libfuncs.cc: ...here.
* optabs-query.c: Moved to...
* optabs-query.cc: ...here.
* optabs-tree.c: Moved to...
* optabs-tree.cc: ...here.
* optabs.c: Moved to...
* optabs.cc: ...here.
* opts-common.c: Moved to...
* opts-common.cc: ...here.
* opts-global.c: Moved to...
* opts-global.cc: ...here.
* opts.c: Moved to...
* opts.cc: ...here.
* passes.c: Moved to...
* passes.cc: ...here.
* plugin.c: Moved to...
* plugin.cc: ...here.
* postreload-gcse.c: Moved to...
* postreload-gcse.cc: ...here.
* postreload.c: Moved to...
* postreload.cc: ...here.
* predict.c: Moved to...
* predict.cc: ...here.
* prefix.c: Moved to...
* prefix.cc: ...here.
* pretty-print.c: Moved to...
* pretty-print.cc: ...here.
* print-rtl-function.c: Moved to...
* print-rtl-function.cc: ...here.
* print-rtl.c: Moved to...
* print-rtl.cc: ...here.
* print-tree.c: Moved to...
* print-tree.cc: ...here.
* profile-count.c: Moved to...
* profile-count.cc: ...here.
* profile.c: Moved to...
* profile.cc: ...here.
* read-md.c: Moved to...
* read-md.cc: ...here.
* read-rtl-function.c: Moved to...
* read-rtl-function.cc: ...here.
* read-rtl.c: Moved to...
* read-rtl.cc: ...here.
* real.c: Moved to...
* real.cc: ...here.
* realmpfr.c: Moved to...
* realmpfr.cc: ...here.
* recog.c: Moved to...
* recog.cc: ...here.
* ree.c: Moved to...
* ree.cc: ...here.
* reg-stack.c: Moved to...
* reg-stack.cc: ...here.
* regcprop.c: Moved to...
* regcprop.cc: ...here.
* reginfo.c: Moved to...
* reginfo.cc: ...here.
* regrename.c: Moved to...
* regrename.cc: ...here.
* regstat.c: Moved to...
* regstat.cc: ...here.
* reload.c: Moved to...
* reload.cc: ...here.
* reload1.c: Moved to...
* reload1.cc: ...here.
* reorg.c: Moved to...
* reorg.cc: ...here.
* resource.c: Moved to...
* resource.cc: ...here.
* rtl-error.c: Moved to...
* rtl-error.cc: ...here.
* rtl-tests.c: Moved to...
* rtl-tests.cc: ...here.
* rtl.c: Moved to...
* rtl.cc: ...here.
* rtlanal.c: Moved to...
* rtlanal.cc: ...here.
* rtlhash.c: Moved to...
* rtlhash.cc: ...here.
* rtlhooks.c: Moved to...
* rtlhooks.cc: ...here.
* rtx-vector-builder.c: Moved to...
* rtx-vector-builder.cc: ...here.
* run-rtl-passes.c: Moved to...
* run-rtl-passes.cc: ...here.
* sancov.c: Moved to...
* sancov.cc: ...here.
* sanopt.c: Moved to...
* sanopt.cc: ...here.
* sbitmap.c: Moved to...
* sbitmap.cc: ...here.
* sched-deps.c: Moved to...
* sched-deps.cc: ...here.
* sched-ebb.c: Moved to...
* sched-ebb.cc: ...here.
* sched-rgn.c: Moved to...
* sched-rgn.cc: ...here.
* sel-sched-dump.c: Moved to...
* sel-sched-dump.cc: ...here.
* sel-sched-ir.c: Moved to...
* sel-sched-ir.cc: ...here.
* sel-sched.c: Moved to...
* sel-sched.cc: ...here.
* selftest-diagnostic.c: Moved to...
* selftest-diagnostic.cc: ...here.
* selftest-rtl.c: Moved to...
* selftest-rtl.cc: ...here.
* selftest-run-tests.c: Moved to...
* selftest-run-tests.cc: ...here.
* selftest.c: Moved to...
* selftest.cc: ...here.
* sese.c: Moved to...
* sese.cc: ...here.
* shrink-wrap.c: Moved to...
* shrink-wrap.cc: ...here.
* simplify-rtx.c: Moved to...
* simplify-rtx.cc: ...here.
* sparseset.c: Moved to...
* sparseset.cc: ...here.
* spellcheck-tree.c: Moved to...
* spellcheck-tree.cc: ...here.
* spellcheck.c: Moved to...
* spellcheck.cc: ...here.
* sreal.c: Moved to...
* sreal.cc: ...here.
* stack-ptr-mod.c: Moved to...
* stack-ptr-mod.cc: ...here.
* statistics.c: Moved to...
* statistics.cc: ...here.
* stmt.c: Moved to...
* stmt.cc: ...here.
* stor-layout.c: Moved to...
* stor-layout.cc: ...here.
* store-motion.c: Moved to...
* store-motion.cc: ...here.
* streamer-hooks.c: Moved to...
* streamer-hooks.cc: ...here.
* stringpool.c: Moved to...
* stringpool.cc: ...here.
* substring-locations.c: Moved to...
* substring-locations.cc: ...here.
* symtab.c: Moved to...
* symtab.cc: ...here.
* target-globals.c: Moved to...
* target-globals.cc: ...here.
* targhooks.c: Moved to...
* targhooks.cc: ...here.
* timevar.c: Moved to...
* timevar.cc: ...here.
* toplev.c: Moved to...
* toplev.cc: ...here.
* tracer.c: Moved to...
* tracer.cc: ...here.
* trans-mem.c: Moved to...
* trans-mem.cc: ...here.
* tree-affine.c: Moved to...
* tree-affine.cc: ...here.
* tree-call-cdce.c: Moved to...
* tree-call-cdce.cc: ...here.
* tree-cfg.c: Moved to...
* tree-cfg.cc: ...here.
* tree-cfgcleanup.c: Moved to...
* tree-cfgcleanup.cc: ...here.
* tree-chrec.c: Moved to...
* tree-chrec.cc: ...here.
* tree-complex.c: Moved to...
* tree-complex.cc: ...here.
* tree-data-ref.c: Moved to...
* tree-data-ref.cc: ...here.
* tree-dfa.c: Moved to...
* tree-dfa.cc: ...here.
* tree-diagnostic.c: Moved to...
* tree-diagnostic.cc: ...here.
* tree-dump.c: Moved to...
* tree-dump.cc: ...here.
* tree-eh.c: Moved to...
* tree-eh.cc: ...here.
* tree-emutls.c: Moved to...
* tree-emutls.cc: ...here.
* tree-if-conv.c: Moved to...
* tree-if-conv.cc: ...here.
* tree-inline.c: Moved to...
* tree-inline.cc: ...here.
* tree-into-ssa.c: Moved to...
* tree-into-ssa.cc: ...here.
* tree-iterator.c: Moved to...
* tree-iterator.cc: ...here.
* tree-loop-distribution.c: Moved to...
* tree-loop-distribution.cc: ...here.
* tree-nested.c: Moved to...
* tree-nested.cc: ...here.
* tree-nrv.c: Moved to...
* tree-nrv.cc: ...here.
* tree-object-size.c: Moved to...
* tree-object-size.cc: ...here.
* tree-outof-ssa.c: Moved to...
* tree-outof-ssa.cc: ...here.
* tree-parloops.c: Moved to...
* tree-parloops.cc: ...here.
* tree-phinodes.c: Moved to...
* tree-phinodes.cc: ...here.
* tree-predcom.c: Moved to...
* tree-predcom.cc: ...here.
* tree-pretty-print.c: Moved to...
* tree-pretty-print.cc: ...here.
* tree-profile.c: Moved to...
* tree-profile.cc: ...here.
* tree-scalar-evolution.c: Moved to...
* tree-scalar-evolution.cc: ...here.
* tree-sra.c: Moved to...
* tree-sra.cc: ...here.
* tree-ssa-address.c: Moved to...
* tree-ssa-address.cc: ...here.
* tree-ssa-alias.c: Moved to...
* tree-ssa-alias.cc: ...here.
* tree-ssa-ccp.c: Moved to...
* tree-ssa-ccp.cc: ...here.
* tree-ssa-coalesce.c: Moved to...
* tree-ssa-coalesce.cc: ...here.
* tree-ssa-copy.c: Moved to...
* tree-ssa-copy.cc: ...here.
* tree-ssa-dce.c: Moved to...
* tree-ssa-dce.cc: ...here.
* tree-ssa-dom.c: Moved to...
* tree-ssa-dom.cc: ...here.
* tree-ssa-dse.c: Moved to...
* tree-ssa-dse.cc: ...here.
* tree-ssa-forwprop.c: Moved to...
* tree-ssa-forwprop.cc: ...here.
* tree-ssa-ifcombine.c: Moved to...
* tree-ssa-ifcombine.cc: ...here.
* tree-ssa-live.c: Moved to...
* tree-ssa-live.cc: ...here.
* tree-ssa-loop-ch.c: Moved to...
* tree-ssa-loop-ch.cc: ...here.
* tree-ssa-loop-im.c: Moved to...
* tree-ssa-loop-im.cc: ...here.
* tree-ssa-loop-ivcanon.c: Moved to...
* tree-ssa-loop-ivcanon.cc: ...here.
* tree-ssa-loop-ivopts.c: Moved to...
* tree-ssa-loop-ivopts.cc: ...here.
* tree-ssa-loop-manip.c: Moved to...
* tree-ssa-loop-manip.cc: ...here.
* tree-ssa-loop-niter.c: Moved to...
* tree-ssa-loop-niter.cc: ...here.
* tree-ssa-loop-prefetch.c: Moved to...
* tree-ssa-loop-prefetch.cc: ...here.
* tree-ssa-loop-split.c: Moved to...
* tree-ssa-loop-split.cc: ...here.
* tree-ssa-loop-unswitch.c: Moved to...
* tree-ssa-loop-unswitch.cc: ...here.
* tree-ssa-loop.c: Moved to...
* tree-ssa-loop.cc: ...here.
* tree-ssa-math-opts.c: Moved to...
* tree-ssa-math-opts.cc: ...here.
* tree-ssa-operands.c: Moved to...
* tree-ssa-operands.cc: ...here.
* tree-ssa-phiopt.c: Moved to...
* tree-ssa-phiopt.cc: ...here.
* tree-ssa-phiprop.c: Moved to...
* tree-ssa-phiprop.cc: ...here.
* tree-ssa-pre.c: Moved to...
* tree-ssa-pre.cc: ...here.
* tree-ssa-propagate.c: Moved to...
* tree-ssa-propagate.cc: ...here.
* tree-ssa-reassoc.c: Moved to...
* tree-ssa-reassoc.cc: ...here.
* tree-ssa-sccvn.c: Moved to...
* tree-ssa-sccvn.cc: ...here.
* tree-ssa-scopedtables.c: Moved to...
* tree-ssa-scopedtables.cc: ...here.
* tree-ssa-sink.c: Moved to...
* tree-ssa-sink.cc: ...here.
* tree-ssa-strlen.c: Moved to...
* tree-ssa-strlen.cc: ...here.
* tree-ssa-structalias.c: Moved to...
* tree-ssa-structalias.cc: ...here.
* tree-ssa-tail-merge.c: Moved to...
* tree-ssa-tail-merge.cc: ...here.
* tree-ssa-ter.c: Moved to...
* tree-ssa-ter.cc: ...here.
* tree-ssa-threadbackward.c: Moved to...
* tree-ssa-threadbackward.cc: ...here.
* tree-ssa-threadedge.c: Moved to...
* tree-ssa-threadedge.cc: ...here.
* tree-ssa-threadupdate.c: Moved to...
* tree-ssa-threadupdate.cc: ...here.
* tree-ssa-uncprop.c: Moved to...
* tree-ssa-uncprop.cc: ...here.
* tree-ssa-uninit.c: Moved to...
* tree-ssa-uninit.cc: ...here.
* tree-ssa.c: Moved to...
* tree-ssa.cc: ...here.
* tree-ssanames.c: Moved to...
* tree-ssanames.cc: ...here.
* tree-stdarg.c: Moved to...
* tree-stdarg.cc: ...here.
* tree-streamer-in.c: Moved to...
* tree-streamer-in.cc: ...here.
* tree-streamer-out.c: Moved to...
* tree-streamer-out.cc: ...here.
* tree-streamer.c: Moved to...
* tree-streamer.cc: ...here.
* tree-switch-conversion.c: Moved to...
* tree-switch-conversion.cc: ...here.
* tree-tailcall.c: Moved to...
* tree-tailcall.cc: ...here.
* tree-vect-data-refs.c: Moved to...
* tree-vect-data-refs.cc: ...here.
* tree-vect-generic.c: Moved to...
* tree-vect-generic.cc: ...here.
* tree-vect-loop-manip.c: Moved to...
* tree-vect-loop-manip.cc: ...here.
* tree-vect-loop.c: Moved to...
* tree-vect-loop.cc: ...here.
* tree-vect-patterns.c: Moved to...
* tree-vect-patterns.cc: ...here.
* tree-vect-slp-patterns.c: Moved to...
* tree-vect-slp-patterns.cc: ...here.
* tree-vect-slp.c: Moved to...
* tree-vect-slp.cc: ...here.
* tree-vect-stmts.c: Moved to...
* tree-vect-stmts.cc: ...here.
* tree-vector-builder.c: Moved to...
* tree-vector-builder.cc: ...here.
* tree-vectorizer.c: Moved to...
* tree-vectorizer.cc: ...here.
* tree-vrp.c: Moved to...
* tree-vrp.cc: ...here.
* tree.c: Moved to...
* tree.cc: ...here.
* tsan.c: Moved to...
* tsan.cc: ...here.
* typed-splay-tree.c: Moved to...
* typed-splay-tree.cc: ...here.
* ubsan.c: Moved to...
* ubsan.cc: ...here.
* valtrack.c: Moved to...
* valtrack.cc: ...here.
* value-prof.c: Moved to...
* value-prof.cc: ...here.
* var-tracking.c: Moved to...
* var-tracking.cc: ...here.
* varasm.c: Moved to...
* varasm.cc: ...here.
* varpool.c: Moved to...
* varpool.cc: ...here.
* vec-perm-indices.c: Moved to...
* vec-perm-indices.cc: ...here.
* vec.c: Moved to...
* vec.cc: ...here.
* vmsdbgout.c: Moved to...
* vmsdbgout.cc: ...here.
* vr-values.c: Moved to...
* vr-values.cc: ...here.
* vtable-verify.c: Moved to...
* vtable-verify.cc: ...here.
* web.c: Moved to...
* web.cc: ...here.
* xcoffout.c: Moved to...
* xcoffout.cc: ...here.
gcc/c-family/ChangeLog:
* c-ada-spec.c: Moved to...
* c-ada-spec.cc: ...here.
* c-attribs.c: Moved to...
* c-attribs.cc: ...here.
* c-common.c: Moved to...
* c-common.cc: ...here.
* c-cppbuiltin.c: Moved to...
* c-cppbuiltin.cc: ...here.
* c-dump.c: Moved to...
* c-dump.cc: ...here.
* c-format.c: Moved to...
* c-format.cc: ...here.
* c-gimplify.c: Moved to...
* c-gimplify.cc: ...here.
* c-indentation.c: Moved to...
* c-indentation.cc: ...here.
* c-lex.c: Moved to...
* c-lex.cc: ...here.
* c-omp.c: Moved to...
* c-omp.cc: ...here.
* c-opts.c: Moved to...
* c-opts.cc: ...here.
* c-pch.c: Moved to...
* c-pch.cc: ...here.
* c-ppoutput.c: Moved to...
* c-ppoutput.cc: ...here.
* c-pragma.c: Moved to...
* c-pragma.cc: ...here.
* c-pretty-print.c: Moved to...
* c-pretty-print.cc: ...here.
* c-semantics.c: Moved to...
* c-semantics.cc: ...here.
* c-ubsan.c: Moved to...
* c-ubsan.cc: ...here.
* c-warn.c: Moved to...
* c-warn.cc: ...here.
* cppspec.c: Moved to...
* cppspec.cc: ...here.
* stub-objc.c: Moved to...
* stub-objc.cc: ...here.
gcc/c/ChangeLog:
* c-aux-info.c: Moved to...
* c-aux-info.cc: ...here.
* c-convert.c: Moved to...
* c-convert.cc: ...here.
* c-decl.c: Moved to...
* c-decl.cc: ...here.
* c-errors.c: Moved to...
* c-errors.cc: ...here.
* c-fold.c: Moved to...
* c-fold.cc: ...here.
* c-lang.c: Moved to...
* c-lang.cc: ...here.
* c-objc-common.c: Moved to...
* c-objc-common.cc: ...here.
* c-parser.c: Moved to...
* c-parser.cc: ...here.
* c-typeck.c: Moved to...
* c-typeck.cc: ...here.
* gccspec.c: Moved to...
* gccspec.cc: ...here.
* gimple-parser.c: Moved to...
* gimple-parser.cc: ...here.
gcc/cp/ChangeLog:
* call.c: Moved to...
* call.cc: ...here.
* class.c: Moved to...
* class.cc: ...here.
* constexpr.c: Moved to...
* constexpr.cc: ...here.
* cp-gimplify.c: Moved to...
* cp-gimplify.cc: ...here.
* cp-lang.c: Moved to...
* cp-lang.cc: ...here.
* cp-objcp-common.c: Moved to...
* cp-objcp-common.cc: ...here.
* cp-ubsan.c: Moved to...
* cp-ubsan.cc: ...here.
* cvt.c: Moved to...
* cvt.cc: ...here.
* cxx-pretty-print.c: Moved to...
* cxx-pretty-print.cc: ...here.
* decl.c: Moved to...
* decl.cc: ...here.
* decl2.c: Moved to...
* decl2.cc: ...here.
* dump.c: Moved to...
* dump.cc: ...here.
* error.c: Moved to...
* error.cc: ...here.
* except.c: Moved to...
* except.cc: ...here.
* expr.c: Moved to...
* expr.cc: ...here.
* friend.c: Moved to...
* friend.cc: ...here.
* g++spec.c: Moved to...
* g++spec.cc: ...here.
* init.c: Moved to...
* init.cc: ...here.
* lambda.c: Moved to...
* lambda.cc: ...here.
* lex.c: Moved to...
* lex.cc: ...here.
* mangle.c: Moved to...
* mangle.cc: ...here.
* method.c: Moved to...
* method.cc: ...here.
* name-lookup.c: Moved to...
* name-lookup.cc: ...here.
* optimize.c: Moved to...
* optimize.cc: ...here.
* parser.c: Moved to...
* parser.cc: ...here.
* pt.c: Moved to...
* pt.cc: ...here.
* ptree.c: Moved to...
* ptree.cc: ...here.
* rtti.c: Moved to...
* rtti.cc: ...here.
* search.c: Moved to...
* search.cc: ...here.
* semantics.c: Moved to...
* semantics.cc: ...here.
* tree.c: Moved to...
* tree.cc: ...here.
* typeck.c: Moved to...
* typeck.cc: ...here.
* typeck2.c: Moved to...
* typeck2.cc: ...here.
* vtable-class-hierarchy.c: Moved to...
* vtable-class-hierarchy.cc: ...here.
gcc/fortran/ChangeLog:
* arith.c: Moved to...
* arith.cc: ...here.
* array.c: Moved to...
* array.cc: ...here.
* bbt.c: Moved to...
* bbt.cc: ...here.
* check.c: Moved to...
* check.cc: ...here.
* class.c: Moved to...
* class.cc: ...here.
* constructor.c: Moved to...
* constructor.cc: ...here.
* convert.c: Moved to...
* convert.cc: ...here.
* cpp.c: Moved to...
* cpp.cc: ...here.
* data.c: Moved to...
* data.cc: ...here.
* decl.c: Moved to...
* decl.cc: ...here.
* dependency.c: Moved to...
* dependency.cc: ...here.
* dump-parse-tree.c: Moved to...
* dump-parse-tree.cc: ...here.
* error.c: Moved to...
* error.cc: ...here.
* expr.c: Moved to...
* expr.cc: ...here.
* f95-lang.c: Moved to...
* f95-lang.cc: ...here.
* frontend-passes.c: Moved to...
* frontend-passes.cc: ...here.
* gfortranspec.c: Moved to...
* gfortranspec.cc: ...here.
* interface.c: Moved to...
* interface.cc: ...here.
* intrinsic.c: Moved to...
* intrinsic.cc: ...here.
* io.c: Moved to...
* io.cc: ...here.
* iresolve.c: Moved to...
* iresolve.cc: ...here.
* match.c: Moved to...
* match.cc: ...here.
* matchexp.c: Moved to...
* matchexp.cc: ...here.
* misc.c: Moved to...
* misc.cc: ...here.
* module.c: Moved to...
* module.cc: ...here.
* openmp.c: Moved to...
* openmp.cc: ...here.
* options.c: Moved to...
* options.cc: ...here.
* parse.c: Moved to...
* parse.cc: ...here.
* primary.c: Moved to...
* primary.cc: ...here.
* resolve.c: Moved to...
* resolve.cc: ...here.
* scanner.c: Moved to...
* scanner.cc: ...here.
* simplify.c: Moved to...
* simplify.cc: ...here.
* st.c: Moved to...
* st.cc: ...here.
* symbol.c: Moved to...
* symbol.cc: ...here.
* target-memory.c: Moved to...
* target-memory.cc: ...here.
* trans-array.c: Moved to...
* trans-array.cc: ...here.
* trans-common.c: Moved to...
* trans-common.cc: ...here.
* trans-const.c: Moved to...
* trans-const.cc: ...here.
* trans-decl.c: Moved to...
* trans-decl.cc: ...here.
* trans-expr.c: Moved to...
* trans-expr.cc: ...here.
* trans-intrinsic.c: Moved to...
* trans-intrinsic.cc: ...here.
* trans-io.c: Moved to...
* trans-io.cc: ...here.
* trans-openmp.c: Moved to...
* trans-openmp.cc: ...here.
* trans-stmt.c: Moved to...
* trans-stmt.cc: ...here.
* trans-types.c: Moved to...
* trans-types.cc: ...here.
* trans.c: Moved to...
* trans.cc: ...here.
gcc/go/ChangeLog:
* go-backend.c: Moved to...
* go-backend.cc: ...here.
* go-lang.c: Moved to...
* go-lang.cc: ...here.
* gospec.c: Moved to...
* gospec.cc: ...here.
gcc/jit/ChangeLog:
* dummy-frontend.c: Moved to...
* dummy-frontend.cc: ...here.
* jit-builtins.c: Moved to...
* jit-builtins.cc: ...here.
* jit-logging.c: Moved to...
* jit-logging.cc: ...here.
* jit-playback.c: Moved to...
* jit-playback.cc: ...here.
* jit-recording.c: Moved to...
* jit-recording.cc: ...here.
* jit-result.c: Moved to...
* jit-result.cc: ...here.
* jit-spec.c: Moved to...
* jit-spec.cc: ...here.
* jit-tempdir.c: Moved to...
* jit-tempdir.cc: ...here.
* jit-w32.c: Moved to...
* jit-w32.cc: ...here.
* libgccjit.c: Moved to...
* libgccjit.cc: ...here.
gcc/lto/ChangeLog:
* common.c: Moved to...
* common.cc: ...here.
* lto-common.c: Moved to...
* lto-common.cc: ...here.
* lto-dump.c: Moved to...
* lto-dump.cc: ...here.
* lto-lang.c: Moved to...
* lto-lang.cc: ...here.
* lto-object.c: Moved to...
* lto-object.cc: ...here.
* lto-partition.c: Moved to...
* lto-partition.cc: ...here.
* lto-symtab.c: Moved to...
* lto-symtab.cc: ...here.
* lto.c: Moved to...
* lto.cc: ...here.
gcc/objc/ChangeLog:
* objc-act.c: Moved to...
* objc-act.cc: ...here.
* objc-encoding.c: Moved to...
* objc-encoding.cc: ...here.
* objc-gnu-runtime-abi-01.c: Moved to...
* objc-gnu-runtime-abi-01.cc: ...here.
* objc-lang.c: Moved to...
* objc-lang.cc: ...here.
* objc-map.c: Moved to...
* objc-map.cc: ...here.
* objc-next-runtime-abi-01.c: Moved to...
* objc-next-runtime-abi-01.cc: ...here.
* objc-next-runtime-abi-02.c: Moved to...
* objc-next-runtime-abi-02.cc: ...here.
* objc-runtime-shared-support.c: Moved to...
* objc-runtime-shared-support.cc: ...here.
gcc/objcp/ChangeLog:
* objcp-decl.c: Moved to...
* objcp-decl.cc: ...here.
* objcp-lang.c: Moved to...
* objcp-lang.cc: ...here.
libcpp/ChangeLog:
* charset.c: Moved to...
* charset.cc: ...here.
* directives.c: Moved to...
* directives.cc: ...here.
* errors.c: Moved to...
* errors.cc: ...here.
* expr.c: Moved to...
* expr.cc: ...here.
* files.c: Moved to...
* files.cc: ...here.
* identifiers.c: Moved to...
* identifiers.cc: ...here.
* init.c: Moved to...
* init.cc: ...here.
* lex.c: Moved to...
* lex.cc: ...here.
* line-map.c: Moved to...
* line-map.cc: ...here.
* macro.c: Moved to...
* macro.cc: ...here.
* makeucnid.c: Moved to...
* makeucnid.cc: ...here.
* mkdeps.c: Moved to...
* mkdeps.cc: ...here.
* pch.c: Moved to...
* pch.cc: ...here.
* symtab.c: Moved to...
* symtab.cc: ...here.
* traditional.c: Moved to...
* traditional.cc: ...here.
Diffstat (limited to 'gcc/cgraphunit.c')
-rw-r--r-- | gcc/cgraphunit.c | 2595 |
1 files changed, 0 insertions, 2595 deletions
diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c deleted file mode 100644 index 8404ac3..0000000 --- a/gcc/cgraphunit.c +++ /dev/null @@ -1,2595 +0,0 @@ -/* Driver of optimization process - Copyright (C) 2003-2022 Free Software Foundation, Inc. - Contributed by Jan Hubicka - -This file is part of GCC. - -GCC is free software; you can redistribute it and/or modify it under -the terms of the GNU General Public License as published by the Free -Software Foundation; either version 3, or (at your option) any later -version. - -GCC is distributed in the hope that it will be useful, but WITHOUT ANY -WARRANTY; without even the implied warranty of MERCHANTABILITY or -FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -for more details. - -You should have received a copy of the GNU General Public License -along with GCC; see the file COPYING3. If not see -<http://www.gnu.org/licenses/>. */ - -/* This module implements main driver of compilation process. - - The main scope of this file is to act as an interface in between - tree based frontends and the backend. - - The front-end is supposed to use following functionality: - - - finalize_function - - This function is called once front-end has parsed whole body of function - and it is certain that the function body nor the declaration will change. - - (There is one exception needed for implementing GCC extern inline - function.) - - - varpool_finalize_decl - - This function has same behavior as the above but is used for static - variables. - - - add_asm_node - - Insert new toplevel ASM statement - - - finalize_compilation_unit - - This function is called once (source level) compilation unit is finalized - and it will no longer change. - - The symbol table is constructed starting from the trivially needed - symbols finalized by the frontend. Functions are lowered into - GIMPLE representation and callgraph/reference lists are constructed. - Those are used to discover other necessary functions and variables. - - At the end the bodies of unreachable functions are removed. - - The function can be called multiple times when multiple source level - compilation units are combined. - - - compile - - This passes control to the back-end. Optimizations are performed and - final assembler is generated. This is done in the following way. Note - that with link time optimization the process is split into three - stages (compile time, linktime analysis and parallel linktime as - indicated bellow). - - Compile time: - - 1) Inter-procedural optimization. - (ipa_passes) - - This part is further split into: - - a) early optimizations. These are local passes executed in - the topological order on the callgraph. - - The purpose of early optimizations is to optimize away simple - things that may otherwise confuse IP analysis. Very simple - propagation across the callgraph is done i.e. to discover - functions without side effects and simple inlining is performed. - - b) early small interprocedural passes. - - Those are interprocedural passes executed only at compilation - time. These include, for example, transactional memory lowering, - unreachable code removal and other simple transformations. - - c) IP analysis stage. All interprocedural passes do their - analysis. - - Interprocedural passes differ from small interprocedural - passes by their ability to operate across whole program - at linktime. Their analysis stage is performed early to - both reduce linking times and linktime memory usage by - not having to represent whole program in memory. - - d) LTO streaming. When doing LTO, everything important gets - streamed into the object file. - - Compile time and or linktime analysis stage (WPA): - - At linktime units gets streamed back and symbol table is - merged. Function bodies are not streamed in and not - available. - e) IP propagation stage. All IP passes execute their - IP propagation. This is done based on the earlier analysis - without having function bodies at hand. - f) Ltrans streaming. When doing WHOPR LTO, the program - is partitioned and streamed into multiple object files. - - Compile time and/or parallel linktime stage (ltrans) - - Each of the object files is streamed back and compiled - separately. Now the function bodies becomes available - again. - - 2) Virtual clone materialization - (cgraph_materialize_clone) - - IP passes can produce copies of existing functions (such - as versioned clones or inline clones) without actually - manipulating their bodies by creating virtual clones in - the callgraph. At this time the virtual clones are - turned into real functions - 3) IP transformation - - All IP passes transform function bodies based on earlier - decision of the IP propagation. - - 4) late small IP passes - - Simple IP passes working within single program partition. - - 5) Expansion - (expand_all_functions) - - At this stage functions that needs to be output into - assembler are identified and compiled in topological order - 6) Output of variables and aliases - Now it is known what variable references was not optimized - out and thus all variables are output to the file. - - Note that with -fno-toplevel-reorder passes 5 and 6 - are combined together in cgraph_output_in_order. - - Finally there are functions to manipulate the callgraph from - backend. - - cgraph_add_new_function is used to add backend produced - functions introduced after the unit is finalized. - The functions are enqueue for later processing and inserted - into callgraph with cgraph_process_new_functions. - - - cgraph_function_versioning - - produces a copy of function into new one (a version) - and apply simple transformations -*/ - -#include "config.h" -#include "system.h" -#include "coretypes.h" -#include "backend.h" -#include "target.h" -#include "rtl.h" -#include "tree.h" -#include "gimple.h" -#include "cfghooks.h" -#include "regset.h" /* FIXME: For reg_obstack. */ -#include "alloc-pool.h" -#include "tree-pass.h" -#include "stringpool.h" -#include "gimple-ssa.h" -#include "cgraph.h" -#include "coverage.h" -#include "lto-streamer.h" -#include "fold-const.h" -#include "varasm.h" -#include "stor-layout.h" -#include "output.h" -#include "cfgcleanup.h" -#include "gimple-fold.h" -#include "gimplify.h" -#include "gimple-iterator.h" -#include "gimplify-me.h" -#include "tree-cfg.h" -#include "tree-into-ssa.h" -#include "tree-ssa.h" -#include "langhooks.h" -#include "toplev.h" -#include "debug.h" -#include "symbol-summary.h" -#include "tree-vrp.h" -#include "ipa-prop.h" -#include "gimple-pretty-print.h" -#include "plugin.h" -#include "ipa-fnsummary.h" -#include "ipa-utils.h" -#include "except.h" -#include "cfgloop.h" -#include "context.h" -#include "pass_manager.h" -#include "tree-nested.h" -#include "dbgcnt.h" -#include "lto-section-names.h" -#include "stringpool.h" -#include "attribs.h" -#include "ipa-inline.h" -#include "omp-offload.h" -#include "symtab-thunks.h" - -/* Queue of cgraph nodes scheduled to be added into cgraph. This is a - secondary queue used during optimization to accommodate passes that - may generate new functions that need to be optimized and expanded. */ -vec<cgraph_node *> cgraph_new_nodes; - -static void expand_all_functions (void); -static void mark_functions_to_output (void); -static void handle_alias_pairs (void); - -/* Return true if this symbol is a function from the C frontend specified - directly in RTL form (with "__RTL"). */ - -bool -symtab_node::native_rtl_p () const -{ - if (TREE_CODE (decl) != FUNCTION_DECL) - return false; - if (!DECL_STRUCT_FUNCTION (decl)) - return false; - return DECL_STRUCT_FUNCTION (decl)->curr_properties & PROP_rtl; -} - -/* Determine if symbol declaration is needed. That is, visible to something - either outside this translation unit, something magic in the system - configury */ -bool -symtab_node::needed_p (void) -{ - /* Double check that no one output the function into assembly file - early. */ - if (!native_rtl_p ()) - gcc_checking_assert - (!DECL_ASSEMBLER_NAME_SET_P (decl) - || !TREE_SYMBOL_REFERENCED (DECL_ASSEMBLER_NAME (decl))); - - if (!definition) - return false; - - if (DECL_EXTERNAL (decl)) - return false; - - /* If the user told us it is used, then it must be so. */ - if (force_output) - return true; - - /* ABI forced symbols are needed when they are external. */ - if (forced_by_abi && TREE_PUBLIC (decl)) - return true; - - /* Keep constructors, destructors and virtual functions. */ - if (TREE_CODE (decl) == FUNCTION_DECL - && (DECL_STATIC_CONSTRUCTOR (decl) || DECL_STATIC_DESTRUCTOR (decl))) - return true; - - /* Externally visible variables must be output. The exception is - COMDAT variables that must be output only when they are needed. */ - if (TREE_PUBLIC (decl) && !DECL_COMDAT (decl)) - return true; - - return false; -} - -/* Head and terminator of the queue of nodes to be processed while building - callgraph. */ - -static symtab_node symtab_terminator (SYMTAB_SYMBOL); -static symtab_node *queued_nodes = &symtab_terminator; - -/* Add NODE to queue starting at QUEUED_NODES. - The queue is linked via AUX pointers and terminated by pointer to 1. */ - -static void -enqueue_node (symtab_node *node) -{ - if (node->aux) - return; - gcc_checking_assert (queued_nodes); - node->aux = queued_nodes; - queued_nodes = node; -} - -/* Process CGRAPH_NEW_FUNCTIONS and perform actions necessary to add these - functions into callgraph in a way so they look like ordinary reachable - functions inserted into callgraph already at construction time. */ - -void -symbol_table::process_new_functions (void) -{ - tree fndecl; - - if (!cgraph_new_nodes.exists ()) - return; - - handle_alias_pairs (); - /* Note that this queue may grow as its being processed, as the new - functions may generate new ones. */ - for (unsigned i = 0; i < cgraph_new_nodes.length (); i++) - { - cgraph_node *node = cgraph_new_nodes[i]; - fndecl = node->decl; - switch (state) - { - case CONSTRUCTION: - /* At construction time we just need to finalize function and move - it into reachable functions list. */ - - cgraph_node::finalize_function (fndecl, false); - call_cgraph_insertion_hooks (node); - enqueue_node (node); - break; - - case IPA: - case IPA_SSA: - case IPA_SSA_AFTER_INLINING: - /* When IPA optimization already started, do all essential - transformations that has been already performed on the whole - cgraph but not on this function. */ - - gimple_register_cfg_hooks (); - if (!node->analyzed) - node->analyze (); - push_cfun (DECL_STRUCT_FUNCTION (fndecl)); - if ((state == IPA_SSA || state == IPA_SSA_AFTER_INLINING) - && !gimple_in_ssa_p (DECL_STRUCT_FUNCTION (fndecl))) - { - bool summaried_computed = ipa_fn_summaries != NULL; - g->get_passes ()->execute_early_local_passes (); - /* Early passes compute inline parameters to do inlining - and splitting. This is redundant for functions added late. - Just throw away whatever it did. */ - if (!summaried_computed) - { - ipa_free_fn_summary (); - ipa_free_size_summary (); - } - } - else if (ipa_fn_summaries != NULL) - compute_fn_summary (node, true); - free_dominance_info (CDI_POST_DOMINATORS); - free_dominance_info (CDI_DOMINATORS); - pop_cfun (); - call_cgraph_insertion_hooks (node); - break; - - case EXPANSION: - /* Functions created during expansion shall be compiled - directly. */ - node->process = 0; - call_cgraph_insertion_hooks (node); - node->expand (); - break; - - default: - gcc_unreachable (); - break; - } - } - - cgraph_new_nodes.release (); -} - -/* As an GCC extension we allow redefinition of the function. The - semantics when both copies of bodies differ is not well defined. - We replace the old body with new body so in unit at a time mode - we always use new body, while in normal mode we may end up with - old body inlined into some functions and new body expanded and - inlined in others. - - ??? It may make more sense to use one body for inlining and other - body for expanding the function but this is difficult to do. */ - -void -cgraph_node::reset (void) -{ - /* If process is set, then we have already begun whole-unit analysis. - This is *not* testing for whether we've already emitted the function. - That case can be sort-of legitimately seen with real function redefinition - errors. I would argue that the front end should never present us with - such a case, but don't enforce that for now. */ - gcc_assert (!process); - - /* Reset our data structures so we can analyze the function again. */ - inlined_to = NULL; - memset (&rtl, 0, sizeof (rtl)); - analyzed = false; - definition = false; - alias = false; - transparent_alias = false; - weakref = false; - cpp_implicit_alias = false; - - remove_callees (); - remove_all_references (); -} - -/* Return true when there are references to the node. INCLUDE_SELF is - true if a self reference counts as a reference. */ - -bool -symtab_node::referred_to_p (bool include_self) -{ - ipa_ref *ref = NULL; - - /* See if there are any references at all. */ - if (iterate_referring (0, ref)) - return true; - /* For functions check also calls. */ - cgraph_node *cn = dyn_cast <cgraph_node *> (this); - if (cn && cn->callers) - { - if (include_self) - return true; - for (cgraph_edge *e = cn->callers; e; e = e->next_caller) - if (e->caller != this) - return true; - } - return false; -} - -/* DECL has been parsed. Take it, queue it, compile it at the whim of the - logic in effect. If NO_COLLECT is true, then our caller cannot stand to have - the garbage collector run at the moment. We would need to either create - a new GC context, or just not compile right now. */ - -void -cgraph_node::finalize_function (tree decl, bool no_collect) -{ - cgraph_node *node = cgraph_node::get_create (decl); - - if (node->definition) - { - /* Nested functions should only be defined once. */ - gcc_assert (!DECL_CONTEXT (decl) - || TREE_CODE (DECL_CONTEXT (decl)) != FUNCTION_DECL); - node->reset (); - node->redefined_extern_inline = true; - } - - /* Set definition first before calling notice_global_symbol so that - it is available to notice_global_symbol. */ - node->definition = true; - notice_global_symbol (decl); - node->lowered = DECL_STRUCT_FUNCTION (decl)->cfg != NULL; - node->semantic_interposition = opt_for_fn (decl, flag_semantic_interposition); - if (!flag_toplevel_reorder) - node->no_reorder = true; - - /* With -fkeep-inline-functions we are keeping all inline functions except - for extern inline ones. */ - if (flag_keep_inline_functions - && DECL_DECLARED_INLINE_P (decl) - && !DECL_EXTERNAL (decl) - && !DECL_DISREGARD_INLINE_LIMITS (decl)) - node->force_output = 1; - - /* __RTL functions were already output as soon as they were parsed (due - to the large amount of global state in the backend). - Mark such functions as "force_output" to reflect the fact that they - will be in the asm file when considering the symbols they reference. - The attempt to output them later on will bail out immediately. */ - if (node->native_rtl_p ()) - node->force_output = 1; - - /* When not optimizing, also output the static functions. (see - PR24561), but don't do so for always_inline functions, functions - declared inline and nested functions. These were optimized out - in the original implementation and it is unclear whether we want - to change the behavior here. */ - if (((!opt_for_fn (decl, optimize) || flag_keep_static_functions - || node->no_reorder) - && !node->cpp_implicit_alias - && !DECL_DISREGARD_INLINE_LIMITS (decl) - && !DECL_DECLARED_INLINE_P (decl) - && !(DECL_CONTEXT (decl) - && TREE_CODE (DECL_CONTEXT (decl)) == FUNCTION_DECL)) - && !DECL_COMDAT (decl) && !DECL_EXTERNAL (decl)) - node->force_output = 1; - - /* If we've not yet emitted decl, tell the debug info about it. */ - if (!TREE_ASM_WRITTEN (decl)) - (*debug_hooks->deferred_inline_function) (decl); - - if (!no_collect) - ggc_collect (); - - if (symtab->state == CONSTRUCTION - && (node->needed_p () || node->referred_to_p ())) - enqueue_node (node); -} - -/* Add the function FNDECL to the call graph. - Unlike finalize_function, this function is intended to be used - by middle end and allows insertion of new function at arbitrary point - of compilation. The function can be either in high, low or SSA form - GIMPLE. - - The function is assumed to be reachable and have address taken (so no - API breaking optimizations are performed on it). - - Main work done by this function is to enqueue the function for later - processing to avoid need the passes to be re-entrant. */ - -void -cgraph_node::add_new_function (tree fndecl, bool lowered) -{ - gcc::pass_manager *passes = g->get_passes (); - cgraph_node *node; - - if (dump_file) - { - struct function *fn = DECL_STRUCT_FUNCTION (fndecl); - const char *function_type = ((gimple_has_body_p (fndecl)) - ? (lowered - ? (gimple_in_ssa_p (fn) - ? "ssa gimple" - : "low gimple") - : "high gimple") - : "to-be-gimplified"); - fprintf (dump_file, - "Added new %s function %s to callgraph\n", - function_type, - fndecl_name (fndecl)); - } - - switch (symtab->state) - { - case PARSING: - cgraph_node::finalize_function (fndecl, false); - break; - case CONSTRUCTION: - /* Just enqueue function to be processed at nearest occurrence. */ - node = cgraph_node::get_create (fndecl); - if (lowered) - node->lowered = true; - cgraph_new_nodes.safe_push (node); - break; - - case IPA: - case IPA_SSA: - case IPA_SSA_AFTER_INLINING: - case EXPANSION: - /* Bring the function into finalized state and enqueue for later - analyzing and compilation. */ - node = cgraph_node::get_create (fndecl); - node->local = false; - node->definition = true; - node->semantic_interposition = opt_for_fn (fndecl, - flag_semantic_interposition); - node->force_output = true; - if (TREE_PUBLIC (fndecl)) - node->externally_visible = true; - if (!lowered && symtab->state == EXPANSION) - { - push_cfun (DECL_STRUCT_FUNCTION (fndecl)); - gimple_register_cfg_hooks (); - bitmap_obstack_initialize (NULL); - execute_pass_list (cfun, passes->all_lowering_passes); - passes->execute_early_local_passes (); - bitmap_obstack_release (NULL); - pop_cfun (); - - lowered = true; - } - if (lowered) - node->lowered = true; - cgraph_new_nodes.safe_push (node); - break; - - case FINISHED: - /* At the very end of compilation we have to do all the work up - to expansion. */ - node = cgraph_node::create (fndecl); - if (lowered) - node->lowered = true; - node->definition = true; - node->semantic_interposition = opt_for_fn (fndecl, - flag_semantic_interposition); - node->analyze (); - push_cfun (DECL_STRUCT_FUNCTION (fndecl)); - gimple_register_cfg_hooks (); - bitmap_obstack_initialize (NULL); - if (!gimple_in_ssa_p (DECL_STRUCT_FUNCTION (fndecl))) - g->get_passes ()->execute_early_local_passes (); - bitmap_obstack_release (NULL); - pop_cfun (); - node->expand (); - break; - - default: - gcc_unreachable (); - } - - /* Set a personality if required and we already passed EH lowering. */ - if (lowered - && (function_needs_eh_personality (DECL_STRUCT_FUNCTION (fndecl)) - == eh_personality_lang)) - DECL_FUNCTION_PERSONALITY (fndecl) = lang_hooks.eh_personality (); -} - -/* Analyze the function scheduled to be output. */ -void -cgraph_node::analyze (void) -{ - if (native_rtl_p ()) - { - analyzed = true; - return; - } - - tree decl = this->decl; - location_t saved_loc = input_location; - input_location = DECL_SOURCE_LOCATION (decl); - - if (thunk) - { - thunk_info *info = thunk_info::get (this); - cgraph_node *t = cgraph_node::get (info->alias); - - create_edge (t, NULL, t->count); - callees->can_throw_external = !TREE_NOTHROW (t->decl); - /* Target code in expand_thunk may need the thunk's target - to be analyzed, so recurse here. */ - if (!t->analyzed && t->definition) - t->analyze (); - if (t->alias) - { - t = t->get_alias_target (); - if (!t->analyzed && t->definition) - t->analyze (); - } - bool ret = expand_thunk (this, false, false); - thunk_info::get (this)->alias = NULL; - if (!ret) - return; - } - if (alias) - resolve_alias (cgraph_node::get (alias_target), transparent_alias); - else if (dispatcher_function) - { - /* Generate the dispatcher body of multi-versioned functions. */ - cgraph_function_version_info *dispatcher_version_info - = function_version (); - if (dispatcher_version_info != NULL - && (dispatcher_version_info->dispatcher_resolver - == NULL_TREE)) - { - tree resolver = NULL_TREE; - gcc_assert (targetm.generate_version_dispatcher_body); - resolver = targetm.generate_version_dispatcher_body (this); - gcc_assert (resolver != NULL_TREE); - } - } - else - { - push_cfun (DECL_STRUCT_FUNCTION (decl)); - - assign_assembler_name_if_needed (decl); - - /* Make sure to gimplify bodies only once. During analyzing a - function we lower it, which will require gimplified nested - functions, so we can end up here with an already gimplified - body. */ - if (!gimple_has_body_p (decl)) - gimplify_function_tree (decl); - - /* Lower the function. */ - if (!lowered) - { - if (first_nested_function (this)) - lower_nested_functions (decl); - - gimple_register_cfg_hooks (); - bitmap_obstack_initialize (NULL); - execute_pass_list (cfun, g->get_passes ()->all_lowering_passes); - compact_blocks (); - bitmap_obstack_release (NULL); - lowered = true; - } - - pop_cfun (); - } - analyzed = true; - - input_location = saved_loc; -} - -/* C++ frontend produce same body aliases all over the place, even before PCH - gets streamed out. It relies on us linking the aliases with their function - in order to do the fixups, but ipa-ref is not PCH safe. Consequently we - first produce aliases without links, but once C++ FE is sure he won't stream - PCH we build the links via this function. */ - -void -symbol_table::process_same_body_aliases (void) -{ - symtab_node *node; - FOR_EACH_SYMBOL (node) - if (node->cpp_implicit_alias && !node->analyzed) - node->resolve_alias - (VAR_P (node->alias_target) - ? (symtab_node *)varpool_node::get_create (node->alias_target) - : (symtab_node *)cgraph_node::get_create (node->alias_target)); - cpp_implicit_aliases_done = true; -} - -/* Process a symver attribute. */ - -static void -process_symver_attribute (symtab_node *n) -{ - tree value = lookup_attribute ("symver", DECL_ATTRIBUTES (n->decl)); - - for (; value != NULL; value = TREE_CHAIN (value)) - { - /* Starting from bintuils 2.35 gas supports: - # Assign foo to bar@V1 and baz@V2. - .symver foo, bar@V1 - .symver foo, baz@V2 - */ - const char *purpose = IDENTIFIER_POINTER (TREE_PURPOSE (value)); - if (strcmp (purpose, "symver") != 0) - continue; - - tree symver = get_identifier_with_length - (TREE_STRING_POINTER (TREE_VALUE (TREE_VALUE (value))), - TREE_STRING_LENGTH (TREE_VALUE (TREE_VALUE (value)))); - symtab_node *def = symtab_node::get_for_asmname (symver); - - if (def) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "duplicate definition of a symbol version"); - inform (DECL_SOURCE_LOCATION (def->decl), - "same version was previously defined here"); - return; - } - if (!n->definition) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "symbol needs to be defined to have a version"); - return; - } - if (DECL_COMMON (n->decl)) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "common symbol cannot be versioned"); - return; - } - if (DECL_COMDAT (n->decl)) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "comdat symbol cannot be versioned"); - return; - } - if (n->weakref) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "%<weakref%> cannot be versioned"); - return; - } - if (!TREE_PUBLIC (n->decl)) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "versioned symbol must be public"); - return; - } - if (DECL_VISIBILITY (n->decl) != VISIBILITY_DEFAULT) - { - error_at (DECL_SOURCE_LOCATION (n->decl), - "versioned symbol must have default visibility"); - return; - } - - /* Create new symbol table entry representing the version. */ - tree new_decl = copy_node (n->decl); - - DECL_INITIAL (new_decl) = NULL_TREE; - if (TREE_CODE (new_decl) == FUNCTION_DECL) - DECL_STRUCT_FUNCTION (new_decl) = NULL; - SET_DECL_ASSEMBLER_NAME (new_decl, symver); - TREE_PUBLIC (new_decl) = 1; - DECL_ATTRIBUTES (new_decl) = NULL; - - symtab_node *symver_node = symtab_node::get_create (new_decl); - symver_node->alias = true; - symver_node->definition = true; - symver_node->symver = true; - symver_node->create_reference (n, IPA_REF_ALIAS, NULL); - symver_node->analyzed = true; - } -} - -/* Process attributes common for vars and functions. */ - -static void -process_common_attributes (symtab_node *node, tree decl) -{ - tree weakref = lookup_attribute ("weakref", DECL_ATTRIBUTES (decl)); - - if (weakref && !lookup_attribute ("alias", DECL_ATTRIBUTES (decl))) - { - warning_at (DECL_SOURCE_LOCATION (decl), OPT_Wattributes, - "%<weakref%> attribute should be accompanied with" - " an %<alias%> attribute"); - DECL_WEAK (decl) = 0; - DECL_ATTRIBUTES (decl) = remove_attribute ("weakref", - DECL_ATTRIBUTES (decl)); - } - - if (lookup_attribute ("no_reorder", DECL_ATTRIBUTES (decl))) - node->no_reorder = 1; - process_symver_attribute (node); -} - -/* Look for externally_visible and used attributes and mark cgraph nodes - accordingly. - - We cannot mark the nodes at the point the attributes are processed (in - handle_*_attribute) because the copy of the declarations available at that - point may not be canonical. For example, in: - - void f(); - void f() __attribute__((used)); - - the declaration we see in handle_used_attribute will be the second - declaration -- but the front end will subsequently merge that declaration - with the original declaration and discard the second declaration. - - Furthermore, we can't mark these nodes in finalize_function because: - - void f() {} - void f() __attribute__((externally_visible)); - - is valid. - - So, we walk the nodes at the end of the translation unit, applying the - attributes at that point. */ - -static void -process_function_and_variable_attributes (cgraph_node *first, - varpool_node *first_var) -{ - cgraph_node *node; - varpool_node *vnode; - - for (node = symtab->first_function (); node != first; - node = symtab->next_function (node)) - { - tree decl = node->decl; - - if (node->alias - && lookup_attribute ("flatten", DECL_ATTRIBUTES (decl))) - { - tree tdecl = node->get_alias_target_tree (); - if (!tdecl || !DECL_P (tdecl) - || !lookup_attribute ("flatten", DECL_ATTRIBUTES (tdecl))) - warning_at (DECL_SOURCE_LOCATION (decl), OPT_Wattributes, - "%<flatten%> attribute is ignored on aliases"); - } - if (DECL_PRESERVE_P (decl)) - node->mark_force_output (); - else if (lookup_attribute ("externally_visible", DECL_ATTRIBUTES (decl))) - { - if (! TREE_PUBLIC (node->decl)) - warning_at (DECL_SOURCE_LOCATION (node->decl), OPT_Wattributes, - "%<externally_visible%>" - " attribute have effect only on public objects"); - } - if (lookup_attribute ("weakref", DECL_ATTRIBUTES (decl)) - && node->definition - && (!node->alias || DECL_INITIAL (decl) != error_mark_node)) - { - /* NODE->DEFINITION && NODE->ALIAS is nonzero for valid weakref - function declarations; DECL_INITIAL is non-null for invalid - weakref functions that are also defined. */ - warning_at (DECL_SOURCE_LOCATION (decl), OPT_Wattributes, - "%<weakref%> attribute ignored" - " because function is defined"); - DECL_WEAK (decl) = 0; - DECL_ATTRIBUTES (decl) = remove_attribute ("weakref", - DECL_ATTRIBUTES (decl)); - DECL_ATTRIBUTES (decl) = remove_attribute ("alias", - DECL_ATTRIBUTES (decl)); - node->alias = false; - node->weakref = false; - node->transparent_alias = false; - } - else if (lookup_attribute ("alias", DECL_ATTRIBUTES (decl)) - && node->definition - && !node->alias) - warning_at (DECL_SOURCE_LOCATION (node->decl), OPT_Wattributes, - "%<alias%> attribute ignored" - " because function is defined"); - - if (lookup_attribute ("always_inline", DECL_ATTRIBUTES (decl)) - && !DECL_DECLARED_INLINE_P (decl) - /* redefining extern inline function makes it DECL_UNINLINABLE. */ - && !DECL_UNINLINABLE (decl)) - warning_at (DECL_SOURCE_LOCATION (decl), OPT_Wattributes, - "%<always_inline%> function might not be inlinable"); - - process_common_attributes (node, decl); - } - for (vnode = symtab->first_variable (); vnode != first_var; - vnode = symtab->next_variable (vnode)) - { - tree decl = vnode->decl; - if (DECL_EXTERNAL (decl) - && DECL_INITIAL (decl)) - varpool_node::finalize_decl (decl); - if (DECL_PRESERVE_P (decl)) - vnode->force_output = true; - else if (lookup_attribute ("externally_visible", DECL_ATTRIBUTES (decl))) - { - if (! TREE_PUBLIC (vnode->decl)) - warning_at (DECL_SOURCE_LOCATION (vnode->decl), OPT_Wattributes, - "%<externally_visible%>" - " attribute have effect only on public objects"); - } - if (lookup_attribute ("weakref", DECL_ATTRIBUTES (decl)) - && vnode->definition - && DECL_INITIAL (decl)) - { - warning_at (DECL_SOURCE_LOCATION (vnode->decl), OPT_Wattributes, - "%<weakref%> attribute ignored" - " because variable is initialized"); - DECL_WEAK (decl) = 0; - DECL_ATTRIBUTES (decl) = remove_attribute ("weakref", - DECL_ATTRIBUTES (decl)); - } - process_common_attributes (vnode, decl); - } -} - -/* Mark DECL as finalized. By finalizing the declaration, frontend instruct the - middle end to output the variable to asm file, if needed or externally - visible. */ - -void -varpool_node::finalize_decl (tree decl) -{ - varpool_node *node = varpool_node::get_create (decl); - - gcc_assert (TREE_STATIC (decl) || DECL_EXTERNAL (decl)); - - if (node->definition) - return; - /* Set definition first before calling notice_global_symbol so that - it is available to notice_global_symbol. */ - node->definition = true; - node->semantic_interposition = flag_semantic_interposition; - notice_global_symbol (decl); - if (!flag_toplevel_reorder) - node->no_reorder = true; - if (TREE_THIS_VOLATILE (decl) || DECL_PRESERVE_P (decl) - /* Traditionally we do not eliminate static variables when not - optimizing and when not doing toplevel reorder. */ - || (node->no_reorder && !DECL_COMDAT (node->decl) - && !DECL_ARTIFICIAL (node->decl))) - node->force_output = true; - - if (symtab->state == CONSTRUCTION - && (node->needed_p () || node->referred_to_p ())) - enqueue_node (node); - if (symtab->state >= IPA_SSA) - node->analyze (); - /* Some frontends produce various interface variables after compilation - finished. */ - if (symtab->state == FINISHED - || (node->no_reorder - && symtab->state == EXPANSION)) - node->assemble_decl (); -} - -/* EDGE is an polymorphic call. Mark all possible targets as reachable - and if there is only one target, perform trivial devirtualization. - REACHABLE_CALL_TARGETS collects target lists we already walked to - avoid duplicate work. */ - -static void -walk_polymorphic_call_targets (hash_set<void *> *reachable_call_targets, - cgraph_edge *edge) -{ - unsigned int i; - void *cache_token; - bool final; - vec <cgraph_node *>targets - = possible_polymorphic_call_targets - (edge, &final, &cache_token); - - if (!reachable_call_targets->add (cache_token)) - { - if (symtab->dump_file) - dump_possible_polymorphic_call_targets - (symtab->dump_file, edge); - - for (i = 0; i < targets.length (); i++) - { - /* Do not bother to mark virtual methods in anonymous namespace; - either we will find use of virtual table defining it, or it is - unused. */ - if (targets[i]->definition - && TREE_CODE - (TREE_TYPE (targets[i]->decl)) - == METHOD_TYPE - && !type_in_anonymous_namespace_p - (TYPE_METHOD_BASETYPE (TREE_TYPE (targets[i]->decl)))) - enqueue_node (targets[i]); - } - } - - /* Very trivial devirtualization; when the type is - final or anonymous (so we know all its derivation) - and there is only one possible virtual call target, - make the edge direct. */ - if (final) - { - if (targets.length () <= 1 && dbg_cnt (devirt)) - { - cgraph_node *target; - if (targets.length () == 1) - target = targets[0]; - else - target = cgraph_node::create - (builtin_decl_implicit (BUILT_IN_UNREACHABLE)); - - if (symtab->dump_file) - { - fprintf (symtab->dump_file, - "Devirtualizing call: "); - print_gimple_stmt (symtab->dump_file, - edge->call_stmt, 0, - TDF_SLIM); - } - if (dump_enabled_p ()) - { - dump_printf_loc (MSG_OPTIMIZED_LOCATIONS, edge->call_stmt, - "devirtualizing call in %s to %s\n", - edge->caller->dump_name (), - target->dump_name ()); - } - - edge = cgraph_edge::make_direct (edge, target); - gimple *new_call = cgraph_edge::redirect_call_stmt_to_callee (edge); - - if (symtab->dump_file) - { - fprintf (symtab->dump_file, "Devirtualized as: "); - print_gimple_stmt (symtab->dump_file, new_call, 0, TDF_SLIM); - } - } - } -} - -/* Issue appropriate warnings for the global declaration DECL. */ - -static void -check_global_declaration (symtab_node *snode) -{ - const char *decl_file; - tree decl = snode->decl; - - /* Warn about any function declared static but not defined. We don't - warn about variables, because many programs have static variables - that exist only to get some text into the object file. */ - if (TREE_CODE (decl) == FUNCTION_DECL - && DECL_INITIAL (decl) == 0 - && DECL_EXTERNAL (decl) - && ! DECL_ARTIFICIAL (decl) - && ! TREE_PUBLIC (decl)) - { - if (warning_suppressed_p (decl, OPT_Wunused)) - ; - else if (snode->referred_to_p (/*include_self=*/false)) - pedwarn (input_location, 0, "%q+F used but never defined", decl); - else - warning (OPT_Wunused_function, "%q+F declared %<static%> but never " - "defined", decl); - /* This symbol is effectively an "extern" declaration now. */ - TREE_PUBLIC (decl) = 1; - } - - /* Warn about static fns or vars defined but not used. */ - if (((warn_unused_function && TREE_CODE (decl) == FUNCTION_DECL) - || (((warn_unused_variable && ! TREE_READONLY (decl)) - || (warn_unused_const_variable > 0 && TREE_READONLY (decl) - && (warn_unused_const_variable == 2 - || (main_input_filename != NULL - && (decl_file = DECL_SOURCE_FILE (decl)) != NULL - && filename_cmp (main_input_filename, - decl_file) == 0)))) - && VAR_P (decl))) - && ! DECL_IN_SYSTEM_HEADER (decl) - && ! snode->referred_to_p (/*include_self=*/false) - /* This TREE_USED check is needed in addition to referred_to_p - above, because the `__unused__' attribute is not being - considered for referred_to_p. */ - && ! TREE_USED (decl) - /* The TREE_USED bit for file-scope decls is kept in the identifier, - to handle multiple external decls in different scopes. */ - && ! (DECL_NAME (decl) && TREE_USED (DECL_NAME (decl))) - && ! DECL_EXTERNAL (decl) - && ! DECL_ARTIFICIAL (decl) - && ! DECL_ABSTRACT_ORIGIN (decl) - && ! TREE_PUBLIC (decl) - /* A volatile variable might be used in some non-obvious way. */ - && (! VAR_P (decl) || ! TREE_THIS_VOLATILE (decl)) - /* Global register variables must be declared to reserve them. */ - && ! (VAR_P (decl) && DECL_REGISTER (decl)) - /* Global ctors and dtors are called by the runtime. */ - && (TREE_CODE (decl) != FUNCTION_DECL - || (!DECL_STATIC_CONSTRUCTOR (decl) - && !DECL_STATIC_DESTRUCTOR (decl))) - /* Otherwise, ask the language. */ - && lang_hooks.decls.warn_unused_global (decl)) - warning_at (DECL_SOURCE_LOCATION (decl), - (TREE_CODE (decl) == FUNCTION_DECL) - ? OPT_Wunused_function - : (TREE_READONLY (decl) - ? OPT_Wunused_const_variable_ - : OPT_Wunused_variable), - "%qD defined but not used", decl); -} - -/* Discover all functions and variables that are trivially needed, analyze - them as well as all functions and variables referred by them */ -static cgraph_node *first_analyzed; -static varpool_node *first_analyzed_var; - -/* FIRST_TIME is set to TRUE for the first time we are called for a - translation unit from finalize_compilation_unit() or false - otherwise. */ - -static void -analyze_functions (bool first_time) -{ - /* Keep track of already processed nodes when called multiple times for - intermodule optimization. */ - cgraph_node *first_handled = first_analyzed; - varpool_node *first_handled_var = first_analyzed_var; - hash_set<void *> reachable_call_targets; - - symtab_node *node; - symtab_node *next; - int i; - ipa_ref *ref; - bool changed = true; - location_t saved_loc = input_location; - - bitmap_obstack_initialize (NULL); - symtab->state = CONSTRUCTION; - input_location = UNKNOWN_LOCATION; - - thunk_info::process_early_thunks (); - - /* Ugly, but the fixup cannot happen at a time same body alias is created; - C++ FE is confused about the COMDAT groups being right. */ - if (symtab->cpp_implicit_aliases_done) - FOR_EACH_SYMBOL (node) - if (node->cpp_implicit_alias) - node->fixup_same_cpp_alias_visibility (node->get_alias_target ()); - build_type_inheritance_graph (); - - if (flag_openmp && first_time) - omp_discover_implicit_declare_target (); - - /* Analysis adds static variables that in turn adds references to new functions. - So we need to iterate the process until it stabilize. */ - while (changed) - { - changed = false; - process_function_and_variable_attributes (first_analyzed, - first_analyzed_var); - - /* First identify the trivially needed symbols. */ - for (node = symtab->first_symbol (); - node != first_analyzed - && node != first_analyzed_var; node = node->next) - { - /* Convert COMDAT group designators to IDENTIFIER_NODEs. */ - node->get_comdat_group_id (); - if (node->needed_p ()) - { - enqueue_node (node); - if (!changed && symtab->dump_file) - fprintf (symtab->dump_file, "Trivially needed symbols:"); - changed = true; - if (symtab->dump_file) - fprintf (symtab->dump_file, " %s", node->dump_asm_name ()); - } - if (node == first_analyzed - || node == first_analyzed_var) - break; - } - symtab->process_new_functions (); - first_analyzed_var = symtab->first_variable (); - first_analyzed = symtab->first_function (); - - if (changed && symtab->dump_file) - fprintf (symtab->dump_file, "\n"); - - /* Lower representation, build callgraph edges and references for all trivially - needed symbols and all symbols referred by them. */ - while (queued_nodes != &symtab_terminator) - { - changed = true; - node = queued_nodes; - queued_nodes = (symtab_node *)queued_nodes->aux; - cgraph_node *cnode = dyn_cast <cgraph_node *> (node); - if (cnode && cnode->definition) - { - cgraph_edge *edge; - tree decl = cnode->decl; - - /* ??? It is possible to create extern inline function - and later using weak alias attribute to kill its body. - See gcc.c-torture/compile/20011119-1.c */ - if (!DECL_STRUCT_FUNCTION (decl) - && !cnode->alias - && !cnode->thunk - && !cnode->dispatcher_function) - { - cnode->reset (); - cnode->redefined_extern_inline = true; - continue; - } - - if (!cnode->analyzed) - cnode->analyze (); - - for (edge = cnode->callees; edge; edge = edge->next_callee) - if (edge->callee->definition - && (!DECL_EXTERNAL (edge->callee->decl) - /* When not optimizing, do not try to analyze extern - inline functions. Doing so is pointless. */ - || opt_for_fn (edge->callee->decl, optimize) - /* Weakrefs needs to be preserved. */ - || edge->callee->alias - /* always_inline functions are inlined even at -O0. */ - || lookup_attribute - ("always_inline", - DECL_ATTRIBUTES (edge->callee->decl)) - /* Multiversioned functions needs the dispatcher to - be produced locally even for extern functions. */ - || edge->callee->function_version ())) - enqueue_node (edge->callee); - if (opt_for_fn (cnode->decl, optimize) - && opt_for_fn (cnode->decl, flag_devirtualize)) - { - cgraph_edge *next; - - for (edge = cnode->indirect_calls; edge; edge = next) - { - next = edge->next_callee; - if (edge->indirect_info->polymorphic) - walk_polymorphic_call_targets (&reachable_call_targets, - edge); - } - } - - /* If decl is a clone of an abstract function, - mark that abstract function so that we don't release its body. - The DECL_INITIAL() of that abstract function declaration - will be later needed to output debug info. */ - if (DECL_ABSTRACT_ORIGIN (decl)) - { - cgraph_node *origin_node - = cgraph_node::get_create (DECL_ABSTRACT_ORIGIN (decl)); - origin_node->used_as_abstract_origin = true; - } - /* Preserve a functions function context node. It will - later be needed to output debug info. */ - if (tree fn = decl_function_context (decl)) - { - cgraph_node *origin_node = cgraph_node::get_create (fn); - enqueue_node (origin_node); - } - } - else - { - varpool_node *vnode = dyn_cast <varpool_node *> (node); - if (vnode && vnode->definition && !vnode->analyzed) - vnode->analyze (); - } - - if (node->same_comdat_group) - { - symtab_node *next; - for (next = node->same_comdat_group; - next != node; - next = next->same_comdat_group) - if (!next->comdat_local_p ()) - enqueue_node (next); - } - for (i = 0; node->iterate_reference (i, ref); i++) - if (ref->referred->definition - && (!DECL_EXTERNAL (ref->referred->decl) - || ((TREE_CODE (ref->referred->decl) != FUNCTION_DECL - && optimize) - || (TREE_CODE (ref->referred->decl) == FUNCTION_DECL - && opt_for_fn (ref->referred->decl, optimize)) - || node->alias - || ref->referred->alias))) - enqueue_node (ref->referred); - symtab->process_new_functions (); - } - } - update_type_inheritance_graph (); - - /* Collect entry points to the unit. */ - if (symtab->dump_file) - { - fprintf (symtab->dump_file, "\n\nInitial "); - symtab->dump (symtab->dump_file); - } - - if (first_time) - { - symtab_node *snode; - FOR_EACH_SYMBOL (snode) - check_global_declaration (snode); - } - - if (symtab->dump_file) - fprintf (symtab->dump_file, "\nRemoving unused symbols:"); - - for (node = symtab->first_symbol (); - node != first_handled - && node != first_handled_var; node = next) - { - next = node->next; - /* For symbols declared locally we clear TREE_READONLY when emitting - the constructor (if one is needed). For external declarations we can - not safely assume that the type is readonly because we may be called - during its construction. */ - if (TREE_CODE (node->decl) == VAR_DECL - && TYPE_P (TREE_TYPE (node->decl)) - && TYPE_NEEDS_CONSTRUCTING (TREE_TYPE (node->decl)) - && DECL_EXTERNAL (node->decl)) - TREE_READONLY (node->decl) = 0; - if (!node->aux && !node->referred_to_p ()) - { - if (symtab->dump_file) - fprintf (symtab->dump_file, " %s", node->dump_name ()); - - /* See if the debugger can use anything before the DECL - passes away. Perhaps it can notice a DECL that is now a - constant and can tag the early DIE with an appropriate - attribute. - - Otherwise, this is the last chance the debug_hooks have - at looking at optimized away DECLs, since - late_global_decl will subsequently be called from the - contents of the now pruned symbol table. */ - if (VAR_P (node->decl) - && !decl_function_context (node->decl)) - { - /* We are reclaiming totally unreachable code and variables - so they effectively appear as readonly. Show that to - the debug machinery. */ - TREE_READONLY (node->decl) = 1; - node->definition = false; - (*debug_hooks->late_global_decl) (node->decl); - } - - node->remove (); - continue; - } - if (cgraph_node *cnode = dyn_cast <cgraph_node *> (node)) - { - tree decl = node->decl; - - if (cnode->definition && !gimple_has_body_p (decl) - && !cnode->alias - && !cnode->thunk) - cnode->reset (); - - gcc_assert (!cnode->definition || cnode->thunk - || cnode->alias - || gimple_has_body_p (decl) - || cnode->native_rtl_p ()); - gcc_assert (cnode->analyzed == cnode->definition); - } - node->aux = NULL; - } - for (;node; node = node->next) - node->aux = NULL; - first_analyzed = symtab->first_function (); - first_analyzed_var = symtab->first_variable (); - if (symtab->dump_file) - { - fprintf (symtab->dump_file, "\n\nReclaimed "); - symtab->dump (symtab->dump_file); - } - bitmap_obstack_release (NULL); - ggc_collect (); - /* Initialize assembler name hash, in particular we want to trigger C++ - mangling and same body alias creation before we free DECL_ARGUMENTS - used by it. */ - if (!seen_error ()) - symtab->symtab_initialize_asm_name_hash (); - - input_location = saved_loc; -} - -/* Check declaration of the type of ALIAS for compatibility with its TARGET - (which may be an ifunc resolver) and issue a diagnostic when they are - not compatible according to language rules (plus a C++ extension for - non-static member functions). */ - -static void -maybe_diag_incompatible_alias (tree alias, tree target) -{ - tree altype = TREE_TYPE (alias); - tree targtype = TREE_TYPE (target); - - bool ifunc = cgraph_node::get (alias)->ifunc_resolver; - tree funcptr = altype; - - if (ifunc) - { - /* Handle attribute ifunc first. */ - if (TREE_CODE (altype) == METHOD_TYPE) - { - /* Set FUNCPTR to the type of the alias target. If the type - is a non-static member function of class C, construct a type - of an ordinary function taking C* as the first argument, - followed by the member function argument list, and use it - instead to check for incompatibility. This conversion is - not defined by the language but an extension provided by - G++. */ - - tree rettype = TREE_TYPE (altype); - tree args = TYPE_ARG_TYPES (altype); - altype = build_function_type (rettype, args); - funcptr = altype; - } - - targtype = TREE_TYPE (targtype); - - if (POINTER_TYPE_P (targtype)) - { - targtype = TREE_TYPE (targtype); - - /* Only issue Wattribute-alias for conversions to void* with - -Wextra. */ - if (VOID_TYPE_P (targtype) && !extra_warnings) - return; - - /* Proceed to handle incompatible ifunc resolvers below. */ - } - else - { - funcptr = build_pointer_type (funcptr); - - error_at (DECL_SOURCE_LOCATION (target), - "%<ifunc%> resolver for %qD must return %qT", - alias, funcptr); - inform (DECL_SOURCE_LOCATION (alias), - "resolver indirect function declared here"); - return; - } - } - - if ((!FUNC_OR_METHOD_TYPE_P (targtype) - || (prototype_p (altype) - && prototype_p (targtype) - && !types_compatible_p (altype, targtype)))) - { - /* Warn for incompatibilities. Avoid warning for functions - without a prototype to make it possible to declare aliases - without knowing the exact type, as libstdc++ does. */ - if (ifunc) - { - funcptr = build_pointer_type (funcptr); - - auto_diagnostic_group d; - if (warning_at (DECL_SOURCE_LOCATION (target), - OPT_Wattribute_alias_, - "%<ifunc%> resolver for %qD should return %qT", - alias, funcptr)) - inform (DECL_SOURCE_LOCATION (alias), - "resolver indirect function declared here"); - } - else - { - auto_diagnostic_group d; - if (warning_at (DECL_SOURCE_LOCATION (alias), - OPT_Wattribute_alias_, - "%qD alias between functions of incompatible " - "types %qT and %qT", alias, altype, targtype)) - inform (DECL_SOURCE_LOCATION (target), - "aliased declaration here"); - } - } -} - -/* Translate the ugly representation of aliases as alias pairs into nice - representation in callgraph. We don't handle all cases yet, - unfortunately. */ - -static void -handle_alias_pairs (void) -{ - alias_pair *p; - unsigned i; - - for (i = 0; alias_pairs && alias_pairs->iterate (i, &p);) - { - symtab_node *target_node = symtab_node::get_for_asmname (p->target); - - /* Weakrefs with target not defined in current unit are easy to handle: - they behave just as external variables except we need to note the - alias flag to later output the weakref pseudo op into asm file. */ - if (!target_node - && lookup_attribute ("weakref", DECL_ATTRIBUTES (p->decl)) != NULL) - { - symtab_node *node = symtab_node::get (p->decl); - if (node) - { - node->alias_target = p->target; - node->weakref = true; - node->alias = true; - node->transparent_alias = true; - } - alias_pairs->unordered_remove (i); - continue; - } - else if (!target_node) - { - error ("%q+D aliased to undefined symbol %qE", p->decl, p->target); - symtab_node *node = symtab_node::get (p->decl); - if (node) - node->alias = false; - alias_pairs->unordered_remove (i); - continue; - } - - if (DECL_EXTERNAL (target_node->decl) - /* We use local aliases for C++ thunks to force the tailcall - to bind locally. This is a hack - to keep it working do - the following (which is not strictly correct). */ - && (TREE_CODE (target_node->decl) != FUNCTION_DECL - || ! DECL_VIRTUAL_P (target_node->decl)) - && ! lookup_attribute ("weakref", DECL_ATTRIBUTES (p->decl))) - { - error ("%q+D aliased to external symbol %qE", - p->decl, p->target); - } - - if (TREE_CODE (p->decl) == FUNCTION_DECL - && target_node && is_a <cgraph_node *> (target_node)) - { - maybe_diag_incompatible_alias (p->decl, target_node->decl); - - maybe_diag_alias_attributes (p->decl, target_node->decl); - - cgraph_node *src_node = cgraph_node::get (p->decl); - if (src_node && src_node->definition) - src_node->reset (); - cgraph_node::create_alias (p->decl, target_node->decl); - alias_pairs->unordered_remove (i); - } - else if (VAR_P (p->decl) - && target_node && is_a <varpool_node *> (target_node)) - { - varpool_node::create_alias (p->decl, target_node->decl); - alias_pairs->unordered_remove (i); - } - else - { - error ("%q+D alias between function and variable is not supported", - p->decl); - inform (DECL_SOURCE_LOCATION (target_node->decl), - "aliased declaration here"); - - alias_pairs->unordered_remove (i); - } - } - vec_free (alias_pairs); -} - - -/* Figure out what functions we want to assemble. */ - -static void -mark_functions_to_output (void) -{ - bool check_same_comdat_groups = false; - cgraph_node *node; - - if (flag_checking) - FOR_EACH_FUNCTION (node) - gcc_assert (!node->process); - - FOR_EACH_FUNCTION (node) - { - tree decl = node->decl; - - gcc_assert (!node->process || node->same_comdat_group); - if (node->process) - continue; - - /* We need to output all local functions that are used and not - always inlined, as well as those that are reachable from - outside the current compilation unit. */ - if (node->analyzed - && !node->thunk - && !node->alias - && !node->inlined_to - && !TREE_ASM_WRITTEN (decl) - && !DECL_EXTERNAL (decl)) - { - node->process = 1; - if (node->same_comdat_group) - { - cgraph_node *next; - for (next = dyn_cast<cgraph_node *> (node->same_comdat_group); - next != node; - next = dyn_cast<cgraph_node *> (next->same_comdat_group)) - if (!next->thunk && !next->alias - && !next->comdat_local_p ()) - next->process = 1; - } - } - else if (node->same_comdat_group) - { - if (flag_checking) - check_same_comdat_groups = true; - } - else - { - /* We should've reclaimed all functions that are not needed. */ - if (flag_checking - && !node->inlined_to - && gimple_has_body_p (decl) - /* FIXME: in ltrans unit when offline copy is outside partition but inline copies - are inside partition, we can end up not removing the body since we no longer - have analyzed node pointing to it. */ - && !node->in_other_partition - && !node->alias - && !node->clones - && !DECL_EXTERNAL (decl)) - { - node->debug (); - internal_error ("failed to reclaim unneeded function"); - } - gcc_assert (node->inlined_to - || !gimple_has_body_p (decl) - || node->in_other_partition - || node->clones - || DECL_ARTIFICIAL (decl) - || DECL_EXTERNAL (decl)); - - } - - } - if (flag_checking && check_same_comdat_groups) - FOR_EACH_FUNCTION (node) - if (node->same_comdat_group && !node->process) - { - tree decl = node->decl; - if (!node->inlined_to - && gimple_has_body_p (decl) - /* FIXME: in an ltrans unit when the offline copy is outside a - partition but inline copies are inside a partition, we can - end up not removing the body since we no longer have an - analyzed node pointing to it. */ - && !node->in_other_partition - && !node->clones - && !DECL_EXTERNAL (decl)) - { - node->debug (); - internal_error ("failed to reclaim unneeded function in same " - "comdat group"); - } - } -} - -/* DECL is FUNCTION_DECL. Initialize datastructures so DECL is a function - in lowered gimple form. IN_SSA is true if the gimple is in SSA. - - Set current_function_decl and cfun to newly constructed empty function body. - return basic block in the function body. */ - -basic_block -init_lowered_empty_function (tree decl, bool in_ssa, profile_count count) -{ - basic_block bb; - edge e; - - current_function_decl = decl; - allocate_struct_function (decl, false); - gimple_register_cfg_hooks (); - init_empty_tree_cfg (); - init_tree_ssa (cfun); - - if (in_ssa) - { - init_ssa_operands (cfun); - cfun->gimple_df->in_ssa_p = true; - cfun->curr_properties |= PROP_ssa; - } - - DECL_INITIAL (decl) = make_node (BLOCK); - BLOCK_SUPERCONTEXT (DECL_INITIAL (decl)) = decl; - - DECL_SAVED_TREE (decl) = error_mark_node; - cfun->curr_properties |= (PROP_gimple_lcf | PROP_gimple_leh | PROP_gimple_any - | PROP_cfg | PROP_loops); - - set_loops_for_fn (cfun, ggc_cleared_alloc<loops> ()); - init_loops_structure (cfun, loops_for_fn (cfun), 1); - loops_for_fn (cfun)->state |= LOOPS_MAY_HAVE_MULTIPLE_LATCHES; - - /* Create BB for body of the function and connect it properly. */ - ENTRY_BLOCK_PTR_FOR_FN (cfun)->count = count; - EXIT_BLOCK_PTR_FOR_FN (cfun)->count = count; - bb = create_basic_block (NULL, ENTRY_BLOCK_PTR_FOR_FN (cfun)); - bb->count = count; - e = make_edge (ENTRY_BLOCK_PTR_FOR_FN (cfun), bb, EDGE_FALLTHRU); - e->probability = profile_probability::always (); - e = make_edge (bb, EXIT_BLOCK_PTR_FOR_FN (cfun), 0); - e->probability = profile_probability::always (); - add_bb_to_loop (bb, ENTRY_BLOCK_PTR_FOR_FN (cfun)->loop_father); - - return bb; -} - -/* Assemble thunks and aliases associated to node. */ - -void -cgraph_node::assemble_thunks_and_aliases (void) -{ - cgraph_edge *e; - ipa_ref *ref; - - for (e = callers; e;) - if (e->caller->thunk - && !e->caller->inlined_to) - { - cgraph_node *thunk = e->caller; - - e = e->next_caller; - expand_thunk (thunk, true, false); - thunk->assemble_thunks_and_aliases (); - } - else - e = e->next_caller; - - FOR_EACH_ALIAS (this, ref) - { - cgraph_node *alias = dyn_cast <cgraph_node *> (ref->referring); - if (!alias->transparent_alias) - { - bool saved_written = TREE_ASM_WRITTEN (decl); - - /* Force assemble_alias to really output the alias this time instead - of buffering it in same alias pairs. */ - TREE_ASM_WRITTEN (decl) = 1; - if (alias->symver) - do_assemble_symver (alias->decl, - DECL_ASSEMBLER_NAME (decl)); - else - do_assemble_alias (alias->decl, - DECL_ASSEMBLER_NAME (decl)); - alias->assemble_thunks_and_aliases (); - TREE_ASM_WRITTEN (decl) = saved_written; - } - } -} - -/* Expand function specified by node. */ - -void -cgraph_node::expand (void) -{ - location_t saved_loc; - - /* We ought to not compile any inline clones. */ - gcc_assert (!inlined_to); - - /* __RTL functions are compiled as soon as they are parsed, so don't - do it again. */ - if (native_rtl_p ()) - return; - - announce_function (decl); - process = 0; - gcc_assert (lowered); - - /* Initialize the default bitmap obstack. */ - bitmap_obstack_initialize (NULL); - get_untransformed_body (); - - /* Generate RTL for the body of DECL. */ - - timevar_push (TV_REST_OF_COMPILATION); - - gcc_assert (symtab->global_info_ready); - - /* Initialize the RTL code for the function. */ - saved_loc = input_location; - input_location = DECL_SOURCE_LOCATION (decl); - - gcc_assert (DECL_STRUCT_FUNCTION (decl)); - push_cfun (DECL_STRUCT_FUNCTION (decl)); - init_function_start (decl); - - gimple_register_cfg_hooks (); - - bitmap_obstack_initialize (®_obstack); /* FIXME, only at RTL generation*/ - - update_ssa (TODO_update_ssa_only_virtuals); - if (ipa_transforms_to_apply.exists ()) - execute_all_ipa_transforms (false); - - /* Perform all tree transforms and optimizations. */ - - /* Signal the start of passes. */ - invoke_plugin_callbacks (PLUGIN_ALL_PASSES_START, NULL); - - execute_pass_list (cfun, g->get_passes ()->all_passes); - - /* Signal the end of passes. */ - invoke_plugin_callbacks (PLUGIN_ALL_PASSES_END, NULL); - - bitmap_obstack_release (®_obstack); - - /* Release the default bitmap obstack. */ - bitmap_obstack_release (NULL); - - /* If requested, warn about function definitions where the function will - return a value (usually of some struct or union type) which itself will - take up a lot of stack space. */ - if (!DECL_EXTERNAL (decl) && TREE_TYPE (decl)) - { - tree ret_type = TREE_TYPE (TREE_TYPE (decl)); - - if (ret_type && TYPE_SIZE_UNIT (ret_type) - && TREE_CODE (TYPE_SIZE_UNIT (ret_type)) == INTEGER_CST - && compare_tree_int (TYPE_SIZE_UNIT (ret_type), - warn_larger_than_size) > 0) - { - unsigned int size_as_int - = TREE_INT_CST_LOW (TYPE_SIZE_UNIT (ret_type)); - - if (compare_tree_int (TYPE_SIZE_UNIT (ret_type), size_as_int) == 0) - warning (OPT_Wlarger_than_, - "size of return value of %q+D is %u bytes", - decl, size_as_int); - else - warning (OPT_Wlarger_than_, - "size of return value of %q+D is larger than %wu bytes", - decl, warn_larger_than_size); - } - } - - gimple_set_body (decl, NULL); - if (DECL_STRUCT_FUNCTION (decl) == 0) - { - /* Stop pointing to the local nodes about to be freed. - But DECL_INITIAL must remain nonzero so we know this - was an actual function definition. */ - if (DECL_INITIAL (decl) != 0) - DECL_INITIAL (decl) = error_mark_node; - } - - input_location = saved_loc; - - ggc_collect (); - timevar_pop (TV_REST_OF_COMPILATION); - - /* Make sure that BE didn't give up on compiling. */ - gcc_assert (TREE_ASM_WRITTEN (decl)); - if (cfun) - pop_cfun (); - - /* It would make a lot more sense to output thunks before function body to - get more forward and fewer backward jumps. This however would need - solving problem with comdats. See PR48668. Also aliases must come after - function itself to make one pass assemblers, like one on AIX, happy. - See PR 50689. - FIXME: Perhaps thunks should be move before function IFF they are not in - comdat groups. */ - assemble_thunks_and_aliases (); - release_body (); -} - -/* Node comparator that is responsible for the order that corresponds - to time when a function was launched for the first time. */ - -int -tp_first_run_node_cmp (const void *pa, const void *pb) -{ - const cgraph_node *a = *(const cgraph_node * const *) pa; - const cgraph_node *b = *(const cgraph_node * const *) pb; - unsigned int tp_first_run_a = a->tp_first_run; - unsigned int tp_first_run_b = b->tp_first_run; - - if (!opt_for_fn (a->decl, flag_profile_reorder_functions) - || a->no_reorder) - tp_first_run_a = 0; - if (!opt_for_fn (b->decl, flag_profile_reorder_functions) - || b->no_reorder) - tp_first_run_b = 0; - - if (tp_first_run_a == tp_first_run_b) - return a->order - b->order; - - /* Functions with time profile must be before these without profile. */ - tp_first_run_a = (tp_first_run_a - 1) & INT_MAX; - tp_first_run_b = (tp_first_run_b - 1) & INT_MAX; - - return tp_first_run_a - tp_first_run_b; -} - -/* Expand all functions that must be output. - - Attempt to topologically sort the nodes so function is output when - all called functions are already assembled to allow data to be - propagated across the callgraph. Use a stack to get smaller distance - between a function and its callees (later we may choose to use a more - sophisticated algorithm for function reordering; we will likely want - to use subsections to make the output functions appear in top-down - order). */ - -static void -expand_all_functions (void) -{ - cgraph_node *node; - cgraph_node **order = XCNEWVEC (cgraph_node *, - symtab->cgraph_count); - cgraph_node **tp_first_run_order = XCNEWVEC (cgraph_node *, - symtab->cgraph_count); - unsigned int expanded_func_count = 0, profiled_func_count = 0; - int order_pos, tp_first_run_order_pos = 0, new_order_pos = 0; - int i; - - order_pos = ipa_reverse_postorder (order); - gcc_assert (order_pos == symtab->cgraph_count); - - /* Garbage collector may remove inline clones we eliminate during - optimization. So we must be sure to not reference them. */ - for (i = 0; i < order_pos; i++) - if (order[i]->process) - { - if (order[i]->tp_first_run - && opt_for_fn (order[i]->decl, flag_profile_reorder_functions)) - tp_first_run_order[tp_first_run_order_pos++] = order[i]; - else - order[new_order_pos++] = order[i]; - } - - /* First output functions with time profile in specified order. */ - qsort (tp_first_run_order, tp_first_run_order_pos, - sizeof (cgraph_node *), tp_first_run_node_cmp); - for (i = 0; i < tp_first_run_order_pos; i++) - { - node = tp_first_run_order[i]; - - if (node->process) - { - expanded_func_count++; - profiled_func_count++; - - if (symtab->dump_file) - fprintf (symtab->dump_file, - "Time profile order in expand_all_functions:%s:%d\n", - node->dump_asm_name (), node->tp_first_run); - node->process = 0; - node->expand (); - } - } - - /* Output functions in RPO so callees get optimized before callers. This - makes ipa-ra and other propagators to work. - FIXME: This is far from optimal code layout. */ - for (i = new_order_pos - 1; i >= 0; i--) - { - node = order[i]; - - if (node->process) - { - expanded_func_count++; - node->process = 0; - node->expand (); - } - } - - if (dump_file) - fprintf (dump_file, "Expanded functions with time profile (%s):%u/%u\n", - main_input_filename, profiled_func_count, expanded_func_count); - - if (symtab->dump_file && tp_first_run_order_pos) - fprintf (symtab->dump_file, "Expanded functions with time profile:%u/%u\n", - profiled_func_count, expanded_func_count); - - symtab->process_new_functions (); - free_gimplify_stack (); - delete ipa_saved_clone_sources; - ipa_saved_clone_sources = NULL; - free (order); - free (tp_first_run_order); -} - -/* This is used to sort the node types by the cgraph order number. */ - -enum cgraph_order_sort_kind -{ - ORDER_FUNCTION, - ORDER_VAR, - ORDER_VAR_UNDEF, - ORDER_ASM -}; - -struct cgraph_order_sort -{ - /* Construct from a cgraph_node. */ - cgraph_order_sort (cgraph_node *node) - : kind (ORDER_FUNCTION), order (node->order) - { - u.f = node; - } - - /* Construct from a varpool_node. */ - cgraph_order_sort (varpool_node *node) - : kind (node->definition ? ORDER_VAR : ORDER_VAR_UNDEF), order (node->order) - { - u.v = node; - } - - /* Construct from a asm_node. */ - cgraph_order_sort (asm_node *node) - : kind (ORDER_ASM), order (node->order) - { - u.a = node; - } - - /* Assembly cgraph_order_sort based on its type. */ - void process (); - - enum cgraph_order_sort_kind kind; - union - { - cgraph_node *f; - varpool_node *v; - asm_node *a; - } u; - int order; -}; - -/* Assembly cgraph_order_sort based on its type. */ - -void -cgraph_order_sort::process () -{ - switch (kind) - { - case ORDER_FUNCTION: - u.f->process = 0; - u.f->expand (); - break; - case ORDER_VAR: - u.v->assemble_decl (); - break; - case ORDER_VAR_UNDEF: - assemble_undefined_decl (u.v->decl); - break; - case ORDER_ASM: - assemble_asm (u.a->asm_str); - break; - default: - gcc_unreachable (); - } -} - -/* Compare cgraph_order_sort by order. */ - -static int -cgraph_order_cmp (const void *a_p, const void *b_p) -{ - const cgraph_order_sort *nodea = (const cgraph_order_sort *)a_p; - const cgraph_order_sort *nodeb = (const cgraph_order_sort *)b_p; - - return nodea->order - nodeb->order; -} - -/* Output all functions, variables, and asm statements in the order - according to their order fields, which is the order in which they - appeared in the file. This implements -fno-toplevel-reorder. In - this mode we may output functions and variables which don't really - need to be output. */ - -static void -output_in_order (void) -{ - int i; - cgraph_node *cnode; - varpool_node *vnode; - asm_node *anode; - auto_vec<cgraph_order_sort> nodes; - cgraph_order_sort *node; - - FOR_EACH_DEFINED_FUNCTION (cnode) - if (cnode->process && !cnode->thunk - && !cnode->alias && cnode->no_reorder) - nodes.safe_push (cgraph_order_sort (cnode)); - - /* There is a similar loop in symbol_table::output_variables. - Please keep them in sync. */ - FOR_EACH_VARIABLE (vnode) - if (vnode->no_reorder - && !DECL_HARD_REGISTER (vnode->decl) - && !DECL_HAS_VALUE_EXPR_P (vnode->decl)) - nodes.safe_push (cgraph_order_sort (vnode)); - - for (anode = symtab->first_asm_symbol (); anode; anode = anode->next) - nodes.safe_push (cgraph_order_sort (anode)); - - /* Sort nodes by order. */ - nodes.qsort (cgraph_order_cmp); - - /* In toplevel reorder mode we output all statics; mark them as needed. */ - FOR_EACH_VEC_ELT (nodes, i, node) - if (node->kind == ORDER_VAR) - node->u.v->finalize_named_section_flags (); - - FOR_EACH_VEC_ELT (nodes, i, node) - node->process (); - - symtab->clear_asm_symbols (); -} - -static void -ipa_passes (void) -{ - gcc::pass_manager *passes = g->get_passes (); - - set_cfun (NULL); - current_function_decl = NULL; - gimple_register_cfg_hooks (); - bitmap_obstack_initialize (NULL); - - invoke_plugin_callbacks (PLUGIN_ALL_IPA_PASSES_START, NULL); - - if (!in_lto_p) - { - execute_ipa_pass_list (passes->all_small_ipa_passes); - if (seen_error ()) - return; - } - - /* This extra symtab_remove_unreachable_nodes pass tends to catch some - devirtualization and other changes where removal iterate. */ - symtab->remove_unreachable_nodes (symtab->dump_file); - - /* If pass_all_early_optimizations was not scheduled, the state of - the cgraph will not be properly updated. Update it now. */ - if (symtab->state < IPA_SSA) - symtab->state = IPA_SSA; - - if (!in_lto_p) - { - /* Generate coverage variables and constructors. */ - coverage_finish (); - - /* Process new functions added. */ - set_cfun (NULL); - current_function_decl = NULL; - symtab->process_new_functions (); - - execute_ipa_summary_passes - ((ipa_opt_pass_d *) passes->all_regular_ipa_passes); - } - - /* Some targets need to handle LTO assembler output specially. */ - if (flag_generate_lto || flag_generate_offload) - targetm.asm_out.lto_start (); - - if (!in_lto_p - || flag_incremental_link == INCREMENTAL_LINK_LTO) - { - if (!quiet_flag) - fprintf (stderr, "Streaming LTO\n"); - if (g->have_offload) - { - section_name_prefix = OFFLOAD_SECTION_NAME_PREFIX; - lto_stream_offload_p = true; - ipa_write_summaries (); - lto_stream_offload_p = false; - } - if (flag_lto) - { - section_name_prefix = LTO_SECTION_NAME_PREFIX; - lto_stream_offload_p = false; - ipa_write_summaries (); - } - } - - if (flag_generate_lto || flag_generate_offload) - targetm.asm_out.lto_end (); - - if (!flag_ltrans - && ((in_lto_p && flag_incremental_link != INCREMENTAL_LINK_LTO) - || !flag_lto || flag_fat_lto_objects)) - execute_ipa_pass_list (passes->all_regular_ipa_passes); - invoke_plugin_callbacks (PLUGIN_ALL_IPA_PASSES_END, NULL); - - bitmap_obstack_release (NULL); -} - - -/* Weakrefs may be associated to external decls and thus not output - at expansion time. Emit all necessary aliases. */ - -void -symbol_table::output_weakrefs (void) -{ - symtab_node *node; - FOR_EACH_SYMBOL (node) - if (node->alias - && !TREE_ASM_WRITTEN (node->decl) - && node->weakref) - { - tree target; - - /* Weakrefs are special by not requiring target definition in current - compilation unit. It is thus bit hard to work out what we want to - alias. - When alias target is defined, we need to fetch it from symtab reference, - otherwise it is pointed to by alias_target. */ - if (node->alias_target) - target = (DECL_P (node->alias_target) - ? DECL_ASSEMBLER_NAME (node->alias_target) - : node->alias_target); - else if (node->analyzed) - target = DECL_ASSEMBLER_NAME (node->get_alias_target ()->decl); - else - gcc_unreachable (); - do_assemble_alias (node->decl, target); - } -} - -/* Perform simple optimizations based on callgraph. */ - -void -symbol_table::compile (void) -{ - if (seen_error ()) - return; - - symtab_node::checking_verify_symtab_nodes (); - - timevar_push (TV_CGRAPHOPT); - if (pre_ipa_mem_report) - dump_memory_report ("Memory consumption before IPA"); - if (!quiet_flag) - fprintf (stderr, "Performing interprocedural optimizations\n"); - state = IPA; - - /* If LTO is enabled, initialize the streamer hooks needed by GIMPLE. */ - if (flag_generate_lto || flag_generate_offload) - lto_streamer_hooks_init (); - - /* Don't run the IPA passes if there was any error or sorry messages. */ - if (!seen_error ()) - { - timevar_start (TV_CGRAPH_IPA_PASSES); - ipa_passes (); - timevar_stop (TV_CGRAPH_IPA_PASSES); - } - /* Do nothing else if any IPA pass found errors or if we are just streaming LTO. */ - if (seen_error () - || ((!in_lto_p || flag_incremental_link == INCREMENTAL_LINK_LTO) - && flag_lto && !flag_fat_lto_objects)) - { - timevar_pop (TV_CGRAPHOPT); - return; - } - - global_info_ready = true; - if (dump_file) - { - fprintf (dump_file, "Optimized "); - symtab->dump (dump_file); - } - if (post_ipa_mem_report) - dump_memory_report ("Memory consumption after IPA"); - timevar_pop (TV_CGRAPHOPT); - - /* Output everything. */ - switch_to_section (text_section); - (*debug_hooks->assembly_start) (); - if (!quiet_flag) - fprintf (stderr, "Assembling functions:\n"); - symtab_node::checking_verify_symtab_nodes (); - - bitmap_obstack_initialize (NULL); - execute_ipa_pass_list (g->get_passes ()->all_late_ipa_passes); - bitmap_obstack_release (NULL); - mark_functions_to_output (); - - /* When weakref support is missing, we automatically translate all - references to NODE to references to its ultimate alias target. - The renaming mechanism uses flag IDENTIFIER_TRANSPARENT_ALIAS and - TREE_CHAIN. - - Set up this mapping before we output any assembler but once we are sure - that all symbol renaming is done. - - FIXME: All this ugliness can go away if we just do renaming at gimple - level by physically rewriting the IL. At the moment we can only redirect - calls, so we need infrastructure for renaming references as well. */ -#ifndef ASM_OUTPUT_WEAKREF - symtab_node *node; - - FOR_EACH_SYMBOL (node) - if (node->alias - && lookup_attribute ("weakref", DECL_ATTRIBUTES (node->decl))) - { - IDENTIFIER_TRANSPARENT_ALIAS - (DECL_ASSEMBLER_NAME (node->decl)) = 1; - TREE_CHAIN (DECL_ASSEMBLER_NAME (node->decl)) - = (node->alias_target ? node->alias_target - : DECL_ASSEMBLER_NAME (node->get_alias_target ()->decl)); - } -#endif - - state = EXPANSION; - - /* Output first asm statements and anything ordered. The process - flag is cleared for these nodes, so we skip them later. */ - output_in_order (); - - timevar_start (TV_CGRAPH_FUNC_EXPANSION); - expand_all_functions (); - timevar_stop (TV_CGRAPH_FUNC_EXPANSION); - - output_variables (); - - process_new_functions (); - state = FINISHED; - output_weakrefs (); - - if (dump_file) - { - fprintf (dump_file, "\nFinal "); - symtab->dump (dump_file); - } - if (!flag_checking) - return; - symtab_node::verify_symtab_nodes (); - /* Double check that all inline clones are gone and that all - function bodies have been released from memory. */ - if (!seen_error ()) - { - cgraph_node *node; - bool error_found = false; - - FOR_EACH_DEFINED_FUNCTION (node) - if (node->inlined_to - || gimple_has_body_p (node->decl)) - { - error_found = true; - node->debug (); - } - if (error_found) - internal_error ("nodes with unreleased memory found"); - } -} - -/* Earlydebug dump file, flags, and number. */ - -static int debuginfo_early_dump_nr; -static FILE *debuginfo_early_dump_file; -static dump_flags_t debuginfo_early_dump_flags; - -/* Debug dump file, flags, and number. */ - -static int debuginfo_dump_nr; -static FILE *debuginfo_dump_file; -static dump_flags_t debuginfo_dump_flags; - -/* Register the debug and earlydebug dump files. */ - -void -debuginfo_early_init (void) -{ - gcc::dump_manager *dumps = g->get_dumps (); - debuginfo_early_dump_nr = dumps->dump_register (".earlydebug", "earlydebug", - "earlydebug", DK_tree, - OPTGROUP_NONE, - false); - debuginfo_dump_nr = dumps->dump_register (".debug", "debug", - "debug", DK_tree, - OPTGROUP_NONE, - false); -} - -/* Initialize the debug and earlydebug dump files. */ - -void -debuginfo_init (void) -{ - gcc::dump_manager *dumps = g->get_dumps (); - debuginfo_dump_file = dump_begin (debuginfo_dump_nr, NULL); - debuginfo_dump_flags = dumps->get_dump_file_info (debuginfo_dump_nr)->pflags; - debuginfo_early_dump_file = dump_begin (debuginfo_early_dump_nr, NULL); - debuginfo_early_dump_flags - = dumps->get_dump_file_info (debuginfo_early_dump_nr)->pflags; -} - -/* Finalize the debug and earlydebug dump files. */ - -void -debuginfo_fini (void) -{ - if (debuginfo_dump_file) - dump_end (debuginfo_dump_nr, debuginfo_dump_file); - if (debuginfo_early_dump_file) - dump_end (debuginfo_early_dump_nr, debuginfo_early_dump_file); -} - -/* Set dump_file to the debug dump file. */ - -void -debuginfo_start (void) -{ - set_dump_file (debuginfo_dump_file); -} - -/* Undo setting dump_file to the debug dump file. */ - -void -debuginfo_stop (void) -{ - set_dump_file (NULL); -} - -/* Set dump_file to the earlydebug dump file. */ - -void -debuginfo_early_start (void) -{ - set_dump_file (debuginfo_early_dump_file); -} - -/* Undo setting dump_file to the earlydebug dump file. */ - -void -debuginfo_early_stop (void) -{ - set_dump_file (NULL); -} - -/* Analyze the whole compilation unit once it is parsed completely. */ - -void -symbol_table::finalize_compilation_unit (void) -{ - timevar_push (TV_CGRAPH); - - /* If we're here there's no current function anymore. Some frontends - are lazy in clearing these. */ - current_function_decl = NULL; - set_cfun (NULL); - - /* Do not skip analyzing the functions if there were errors, we - miss diagnostics for following functions otherwise. */ - - /* Emit size functions we didn't inline. */ - finalize_size_functions (); - - /* Mark alias targets necessary and emit diagnostics. */ - handle_alias_pairs (); - - if (!quiet_flag) - { - fprintf (stderr, "\nAnalyzing compilation unit\n"); - fflush (stderr); - } - - if (flag_dump_passes) - dump_passes (); - - /* Gimplify and lower all functions, compute reachability and - remove unreachable nodes. */ - analyze_functions (/*first_time=*/true); - - /* Mark alias targets necessary and emit diagnostics. */ - handle_alias_pairs (); - - /* Gimplify and lower thunks. */ - analyze_functions (/*first_time=*/false); - - /* All nested functions should be lowered now. */ - nested_function_info::release (); - - /* Offloading requires LTO infrastructure. */ - if (!in_lto_p && g->have_offload) - flag_generate_offload = 1; - - if (!seen_error ()) - { - /* Give the frontends the chance to emit early debug based on - what is still reachable in the TU. */ - (*lang_hooks.finalize_early_debug) (); - - /* Clean up anything that needs cleaning up after initial debug - generation. */ - debuginfo_early_start (); - (*debug_hooks->early_finish) (main_input_filename); - debuginfo_early_stop (); - } - - /* Finally drive the pass manager. */ - compile (); - - timevar_pop (TV_CGRAPH); -} - -/* Reset all state within cgraphunit.c so that we can rerun the compiler - within the same process. For use by toplev::finalize. */ - -void -cgraphunit_c_finalize (void) -{ - gcc_assert (cgraph_new_nodes.length () == 0); - cgraph_new_nodes.truncate (0); - - queued_nodes = &symtab_terminator; - - first_analyzed = NULL; - first_analyzed_var = NULL; -} - -/* Creates a wrapper from cgraph_node to TARGET node. Thunk is used for this - kind of wrapper method. */ - -void -cgraph_node::create_wrapper (cgraph_node *target) -{ - /* Preserve DECL_RESULT so we get right by reference flag. */ - tree decl_result = DECL_RESULT (decl); - - /* Remove the function's body but keep arguments to be reused - for thunk. */ - release_body (true); - reset (); - - DECL_UNINLINABLE (decl) = false; - DECL_RESULT (decl) = decl_result; - DECL_INITIAL (decl) = NULL; - allocate_struct_function (decl, false); - set_cfun (NULL); - - /* Turn alias into thunk and expand it into GIMPLE representation. */ - definition = true; - semantic_interposition = opt_for_fn (decl, flag_semantic_interposition); - - /* Create empty thunk, but be sure we did not keep former thunk around. - In that case we would need to preserve the info. */ - gcc_checking_assert (!thunk_info::get (this)); - thunk_info::get_create (this); - thunk = true; - create_edge (target, NULL, count); - callees->can_throw_external = !TREE_NOTHROW (target->decl); - - tree arguments = DECL_ARGUMENTS (decl); - - while (arguments) - { - TREE_ADDRESSABLE (arguments) = false; - arguments = TREE_CHAIN (arguments); - } - - expand_thunk (this, false, true); - thunk_info::remove (this); - - /* Inline summary set-up. */ - analyze (); - inline_analyze_function (this); -} |