aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorAndré Goddard Rosa <andre.goddard@gmail.com>2009-12-14 21:01:00 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2009-12-15 11:53:32 -0500
commitc5484d7c0a533de6198cb474097e33b174f9c565 (patch)
treeb546f0864d85724786157fff343723653d517865 /lib
parentd4be151b2180fbbc6729dfaa16280d150e3fab1f (diff)
vsprintf: factor out skip_space code in a separate function
When converting more caller sites, the inline decision will be left up to gcc. It decreases code size: text data bss dec hex filename 15710 0 8 15718 3d66 vsprintf.o (ex lib/lib.a-BEFORE) 15534 0 8 15542 3cb6 vsprintf.o (ex lib/lib.a-AFTER) Signed-off-by: André Goddard Rosa <andre.goddard@gmail.com> Acked-by: Frederic Weisbecker <fweisbec@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'lib')
-rw-r--r--lib/vsprintf.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/lib/vsprintf.c b/lib/vsprintf.c
index f9532e09b608..a315138ece55 100644
--- a/lib/vsprintf.c
+++ b/lib/vsprintf.c
@@ -1786,6 +1786,13 @@ EXPORT_SYMBOL_GPL(bprintf);
1786 1786
1787#endif /* CONFIG_BINARY_PRINTF */ 1787#endif /* CONFIG_BINARY_PRINTF */
1788 1788
1789static noinline char *skip_space(const char *str)
1790{
1791 while (isspace(*str))
1792 ++str;
1793 return (char *)str;
1794}
1795
1789/** 1796/**
1790 * vsscanf - Unformat a buffer into a list of arguments 1797 * vsscanf - Unformat a buffer into a list of arguments
1791 * @buf: input buffer 1798 * @buf: input buffer
@@ -1807,10 +1814,8 @@ int vsscanf(const char *buf, const char *fmt, va_list args)
1807 * white space, including none, in the input. 1814 * white space, including none, in the input.
1808 */ 1815 */
1809 if (isspace(*fmt)) { 1816 if (isspace(*fmt)) {
1810 while (isspace(*fmt)) 1817 fmt = skip_space(fmt);
1811 ++fmt; 1818 str = skip_space(str);
1812 while (isspace(*str))
1813 ++str;
1814 } 1819 }
1815 1820
1816 /* anything that is not a conversion must match exactly */ 1821 /* anything that is not a conversion must match exactly */
@@ -1880,8 +1885,7 @@ int vsscanf(const char *buf, const char *fmt, va_list args)
1880 if (field_width == -1) 1885 if (field_width == -1)
1881 field_width = INT_MAX; 1886 field_width = INT_MAX;
1882 /* first, skip leading white space in buffer */ 1887 /* first, skip leading white space in buffer */
1883 while (isspace(*str)) 1888 str = skip_space(str);
1884 str++;
1885 1889
1886 /* now copy until next white space */ 1890 /* now copy until next white space */
1887 while (*str && !isspace(*str) && field_width--) 1891 while (*str && !isspace(*str) && field_width--)
@@ -1923,8 +1927,7 @@ int vsscanf(const char *buf, const char *fmt, va_list args)
1923 /* have some sort of integer conversion. 1927 /* have some sort of integer conversion.
1924 * first, skip white space in buffer. 1928 * first, skip white space in buffer.
1925 */ 1929 */
1926 while (isspace(*str)) 1930 str = skip_space(str);
1927 str++;
1928 1931
1929 digit = *str; 1932 digit = *str;
1930 if (is_sign && digit == '-') 1933 if (is_sign && digit == '-')