aboutsummaryrefslogtreecommitdiff
path: root/gcc/ipa.c
diff options
context:
space:
mode:
authorGeorg-Johann Lay <avr@gjlay.de>2012-01-10 09:42:10 +0000
committerGeorg-Johann Lay <gjl@gcc.gnu.org>2012-01-10 09:42:10 +0000
commitcba300dd7dfadf5069d9943c6a54c65a34614d20 (patch)
tree835d7eb99a52b9c049a452e8468cb7613fa1e7ed /gcc/ipa.c
parent59c615478de5b0f61ee750b8e0d21b5219407aba (diff)
downloadgcc-cba300dd7dfadf5069d9943c6a54c65a34614d20.zip
gcc-cba300dd7dfadf5069d9943c6a54c65a34614d20.tar.gz
gcc-cba300dd7dfadf5069d9943c6a54c65a34614d20.tar.bz2
re PR target/49868 (Implement named address space to place/access data in flash memory)
libgcc/ PR target/49868 Extend __pgmx semantics to linearize memory. * config/avr/t-avr (LIB1ASMFUNCS): Add _xload_1, _movmemx. * config/avr/lib1funcs.S (__xload_1): New function. (__movmemx_qi, __movmemx_hi): New functions. (__xload_2, __xload_3, __xload_4): Rewrite to fit new __pgmx semantics. gcc/ PR target/49868 Extend __pgmx semantics to linearize memory. * config/avr/avr.md (mov<mode>): Use avr_xload_libgcc_p to determine if code comes inline or from libgcc. (MOVMEM_r_d:HI): Add "w" to constraint for better preference. (movmem_qi, movmem_qi): Set constraint #2 to "n". (movmem_qi_elpm, movmem_hi_elpm): Remove insns. (movmemx_qi, movmemx_hi): New insns. (xload_<mode>_libgcc): Rewrite to new insn condition. (xload_<mode>): Remove insns. * config/avr/avr.c (avr_out_xload): Rewrite: Only need to handle cases that don't satisfy avr_xload_libgcc_p(). (avr_addr_space_convert): Allow converting in any direction. (avr_addr_space_subset_p): Return always true. (avr_xload_libgcc_p): Rewrite to fit new __pgmx semantics. (avr_emit_movmemhi): Ditto. (avr_out_lpm): No need to handle ADDR_SPACE_PGMX any more. (avr_out_movmem): Ditto. (AVR_SYMBOL_FLAG_PROGMEM): New macro. (AVR_SYMBOL_SET_ADDR_SPACE): New macro. (AVR_SYMBOL_GET_ADDR_SPACE): New macro. (avr_encode_section_info): Encode 'progmem' in symbol flags. (output_reload_in_const): Don't zero-extend any 24-bit symbols. From-SVN: r183058
Diffstat (limited to 'gcc/ipa.c')
0 files changed, 0 insertions, 0 deletions