-/* { dg-do compile } */
-/* { dg-skip-if "" { ! { arm_thumb1_ok || arm_thumb2_ok } } } */
-/* { dg-options "-mthumb -Os" } */
-/* { dg-final { scan-assembler "push\t\{r3" { target { ! arm*-*-uclinuxfdpiceabi } } } } */
-/* { dg-final { scan-assembler-not "\[^\-e\]r8" { target { ! arm*-*-uclinuxfdpiceabi } } } } */
+/* { dg-require-effective-target arm_arch_v7a_thumb_ok } */
+/* { dg-options "-Os" } */
+/* { dg-add-options arm_arch_v7a_thumb } */
+/* { dg-final { scan-assembler "push\t\{r3" } } */
+/* { dg-final { scan-assembler-not "push\t.*r8" } } */
-extern int hist_verify;
-extern int a1;
extern char *pre_process_line (char*);
-extern char* str_cpy (char*, char*);
-extern int str_len (char*);
-extern char* x_malloc (int);
-#define savestring(x) (char *)str_cpy (x_malloc (1 + str_len (x)), (x))
+extern char* x_strdup (const char*);
char *
history_expand_line_internal (char* line)
{
char *new_line;
- int old_verify;
- int a = a1;
- old_verify = hist_verify;
- hist_verify = 0;
new_line = pre_process_line (line);
- hist_verify = old_verify + a;
- return (new_line == line) ? savestring (line) : new_line;
+ asm ("nop": : :"r4","r5","r6");
+ return (new_line == line) ? x_strdup (line) : new_line;
}
+
-/* { dg-do compile } */
-/* { dg-skip-if "" { ! { arm_thumb1_ok || arm_thumb2_ok } } } */
-/* { dg-options "-mthumb -Os" } */
-/* { dg-final { scan-assembler "push\t\{r3" { target { ! arm*-*-uclinuxfdpiceabi } } } } */
-/* { dg-final { scan-assembler-not "\[^\-e\]r8" { target { ! arm*-*-uclinuxfdpiceabi } } } } */
+/* { dg-require-effective-target arm_arch_v7a_thumb_ok } */
+/* { dg-options "-Os" } */
+/* { dg-add-options arm_arch_v7a_thumb } */
+/* { dg-final { scan-assembler "push\t\{r3" } } */
+/* { dg-final { scan-assembler-not "push\t.*r8" } } */
-extern int hist_verify;
-extern int a1;
extern char *pre_process_line (char*);
-extern char* savestring1 (char*, char*);
-extern char* str_cpy (char*, char*);
-extern int str_len (char*);
-extern char* x_malloc (int);
-#define savestring(x) (char *)str_cpy (x_malloc (1 + str_len (x)), (x))
-
+extern char* x_strdup (const char*);
+extern char* x_strdup2 (const char*, const char*);
char *
history_expand_line_internal (char* line)
{
char *new_line;
- int old_verify;
- int a = a1;
- old_verify = hist_verify;
- hist_verify = 0;
new_line = pre_process_line (line);
- hist_verify = old_verify + a;
+ asm ("nop": : :"r4","r5","r6");
/* Two tail calls here, but r3 is not used to pass values. */
- return (new_line == line) ? savestring (line) : savestring1 (new_line, line);
+ return (new_line == line) ? x_strdup (line) : x_strdup2 (new_line, line);
}
-/* { dg-do compile } */
-/* { dg-require-effective-target arm_thumb2_ok } */
-/* { dg-options "-mthumb -Os" } */
+/* { dg-require-effective-target arm_arch_v7a_thumb_ok } */
+/* { dg-options "-Os" } */
+/* { dg-add-options arm_arch_v7a_thumb } */
/* { dg-final { scan-assembler "push\t.*r8" } } */
-/* { dg-final { scan-assembler-not "push\t*r3" } } */
+/* { dg-final { scan-assembler-not "push\t.*r3" } } */
-extern int hist_verify;
extern char *pre_process_line (char*);
-extern char* savestring1 (char*, char*, int, int);
-extern char* str_cpy (char*, char*);
-extern int str_len (char*);
-extern char* x_malloc (int);
-#define savestring(x) (char *)str_cpy (x_malloc (1 + str_len (x)), (x))
+extern char* x_strdup (const char*);
+extern char* x_strdup2 (const char*, const char*, int, int);
char *
history_expand_line_internal (char* line)
{
char *new_line;
- int old_verify;
-
- old_verify = hist_verify;
- hist_verify = 0;
new_line = pre_process_line (line);
- hist_verify = old_verify;
+ asm ("nop": : :"r4","r5","r6");
/* Two tail calls here, but r3 is used to pass values. */
- return (new_line == line) ? savestring (line) :
- savestring1 (new_line, line, 0, old_verify+1);
+ return (new_line == line) ? x_strdup (line) :
+ x_strdup2 (new_line, line, 0, 1);
}