Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | #include <linux/string.h> |
Al Viro | 784d569 | 2016-01-11 11:04:34 -0500 | [diff] [blame] | 3 | #include <linux/export.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 | |
Paolo Ciarrocchi | f73920c | 2008-02-22 23:09:56 +0100 | [diff] [blame] | 5 | char *strstr(const char *cs, const char *ct) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 6 | { |
| 7 | int d0, d1; |
Paolo Ciarrocchi | f73920c | 2008-02-22 23:09:56 +0100 | [diff] [blame] | 8 | register char *__res; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 9 | __asm__ __volatile__( |
| 10 | "movl %6,%%edi\n\t" |
| 11 | "repne\n\t" |
| 12 | "scasb\n\t" |
| 13 | "notl %%ecx\n\t" |
| 14 | "decl %%ecx\n\t" /* NOTE! This also sets Z if searchstring='' */ |
| 15 | "movl %%ecx,%%edx\n" |
| 16 | "1:\tmovl %6,%%edi\n\t" |
| 17 | "movl %%esi,%%eax\n\t" |
| 18 | "movl %%edx,%%ecx\n\t" |
| 19 | "repe\n\t" |
| 20 | "cmpsb\n\t" |
| 21 | "je 2f\n\t" /* also works for empty string, see above */ |
| 22 | "xchgl %%eax,%%esi\n\t" |
| 23 | "incl %%esi\n\t" |
| 24 | "cmpb $0,-1(%%eax)\n\t" |
| 25 | "jne 1b\n\t" |
| 26 | "xorl %%eax,%%eax\n\t" |
| 27 | "2:" |
Paolo Ciarrocchi | 209b580 | 2008-08-02 21:24:45 +0200 | [diff] [blame] | 28 | : "=a" (__res), "=&c" (d0), "=&S" (d1) |
| 29 | : "0" (0), "1" (0xffffffff), "2" (cs), "g" (ct) |
| 30 | : "dx", "di"); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | return __res; |
| 32 | } |
Al Viro | 784d569 | 2016-01-11 11:04:34 -0500 | [diff] [blame] | 33 | EXPORT_SYMBOL(strstr); |