mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 04:33:26 +02:00
seq/proc: modify seq_put_decimal_[u]ll to take a const char *, not char
Allow some seq_puts removals by taking a string instead of a single char. [akpm@linux-foundation.org: update vmstat_show(), per Joe] Link: http://lkml.kernel.org/r/667e1cf3d436de91a5698170a1e98d882905e956.1470704995.git.joe@perches.com Signed-off-by: Joe Perches <joe@perches.com> Cc: Joe Perches <joe@perches.com> Cc: Andi Kleen <andi@firstfloor.org> Cc: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
f7a5f132b4
commit
75ba1d07fd
@@ -679,11 +679,11 @@ EXPORT_SYMBOL(seq_puts);
|
||||
/*
|
||||
* A helper routine for putting decimal numbers without rich format of printf().
|
||||
* only 'unsigned long long' is supported.
|
||||
* This routine will put one byte delimiter + number into seq_file.
|
||||
* This routine will put strlen(delimiter) + number into seq_file.
|
||||
* This routine is very quick when you show lots of numbers.
|
||||
* In usual cases, it will be better to use seq_printf(). It's easier to read.
|
||||
*/
|
||||
void seq_put_decimal_ull(struct seq_file *m, char delimiter,
|
||||
void seq_put_decimal_ull(struct seq_file *m, const char *delimiter,
|
||||
unsigned long long num)
|
||||
{
|
||||
int len;
|
||||
@@ -691,8 +691,15 @@ void seq_put_decimal_ull(struct seq_file *m, char delimiter,
|
||||
if (m->count + 2 >= m->size) /* we'll write 2 bytes at least */
|
||||
goto overflow;
|
||||
|
||||
if (delimiter)
|
||||
m->buf[m->count++] = delimiter;
|
||||
len = strlen(delimiter);
|
||||
if (m->count + len >= m->size)
|
||||
goto overflow;
|
||||
|
||||
memcpy(m->buf + m->count, delimiter, len);
|
||||
m->count += len;
|
||||
|
||||
if (m->count + 1 >= m->size)
|
||||
goto overflow;
|
||||
|
||||
if (num < 10) {
|
||||
m->buf[m->count++] = num + '0';
|
||||
@@ -702,6 +709,7 @@ void seq_put_decimal_ull(struct seq_file *m, char delimiter,
|
||||
len = num_to_str(m->buf + m->count, m->size - m->count, num);
|
||||
if (!len)
|
||||
goto overflow;
|
||||
|
||||
m->count += len;
|
||||
return;
|
||||
|
||||
@@ -710,19 +718,42 @@ overflow:
|
||||
}
|
||||
EXPORT_SYMBOL(seq_put_decimal_ull);
|
||||
|
||||
void seq_put_decimal_ll(struct seq_file *m, char delimiter, long long num)
|
||||
void seq_put_decimal_ll(struct seq_file *m, const char *delimiter, long long num)
|
||||
{
|
||||
int len;
|
||||
|
||||
if (m->count + 3 >= m->size) /* we'll write 2 bytes at least */
|
||||
goto overflow;
|
||||
|
||||
len = strlen(delimiter);
|
||||
if (m->count + len >= m->size)
|
||||
goto overflow;
|
||||
|
||||
memcpy(m->buf + m->count, delimiter, len);
|
||||
m->count += len;
|
||||
|
||||
if (m->count + 2 >= m->size)
|
||||
goto overflow;
|
||||
|
||||
if (num < 0) {
|
||||
if (m->count + 3 >= m->size) {
|
||||
seq_set_overflow(m);
|
||||
return;
|
||||
}
|
||||
if (delimiter)
|
||||
m->buf[m->count++] = delimiter;
|
||||
m->buf[m->count++] = '-';
|
||||
num = -num;
|
||||
delimiter = '-';
|
||||
}
|
||||
seq_put_decimal_ull(m, delimiter, num);
|
||||
|
||||
if (num < 10) {
|
||||
m->buf[m->count++] = num + '0';
|
||||
return;
|
||||
}
|
||||
|
||||
len = num_to_str(m->buf + m->count, m->size - m->count, num);
|
||||
if (!len)
|
||||
goto overflow;
|
||||
|
||||
m->count += len;
|
||||
return;
|
||||
|
||||
overflow:
|
||||
seq_set_overflow(m);
|
||||
}
|
||||
EXPORT_SYMBOL(seq_put_decimal_ll);
|
||||
|
||||
|
Reference in New Issue
Block a user