diff options
author | sayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-04-14 20:23:27 +0000 |
---|---|---|
committer | sayle <sayle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2003-04-14 20:23:27 +0000 |
commit | 6248e34545032ef1f4810a6ffbcb77fd0bfb3f34 (patch) | |
tree | affbca36245c345c26aa8393d0f487eadfbc22c9 /gcc/builtins.c | |
parent | edc21ba8088e0e485b3bdccaba28005747e2ba61 (diff) | |
download | gcc-6248e34545032ef1f4810a6ffbcb77fd0bfb3f34.tar.gz |
* builtins.c (expand_builtin_strlen): Evaluate the lengths of
string literals at compile-time.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@65585 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/builtins.c')
-rw-r--r-- | gcc/builtins.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c index 1519593b883..89f9531c8d3 100644 --- a/gcc/builtins.c +++ b/gcc/builtins.c @@ -1935,14 +1935,18 @@ expand_builtin_strlen (exp, target) else { rtx pat; - tree src = TREE_VALUE (arglist); - - int align - = get_pointer_alignment (src, BIGGEST_ALIGNMENT) / BITS_PER_UNIT; - + tree len, src = TREE_VALUE (arglist); rtx result, src_reg, char_rtx, before_strlen; enum machine_mode insn_mode = value_mode, char_mode; enum insn_code icode = CODE_FOR_nothing; + int align; + + /* If the length can be computed at compile-time, return it. */ + len = c_strlen (src); + if (len) + return expand_expr (len, target, value_mode, EXPAND_NORMAL); + + align = get_pointer_alignment (src, BIGGEST_ALIGNMENT) / BITS_PER_UNIT; /* If SRC is not a pointer type, don't do this operation inline. */ if (align == 0) |