diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/Kconfig | 9 | ||||
| -rw-r--r-- | lib/Makefile | 5 | ||||
| -rw-r--r-- | lib/bitmap.c | 12 | ||||
| -rw-r--r-- | lib/dma-debug.c | 10 | ||||
| -rw-r--r-- | lib/dynamic_queue_limits.c | 18 | ||||
| -rw-r--r-- | lib/list_debug.c | 3 | ||||
| -rw-r--r-- | lib/radix-tree.c | 15 | ||||
| -rw-r--r-- | lib/spinlock_debug.c | 2 | ||||
| -rw-r--r-- | lib/stmp_device.c | 80 | ||||
| -rw-r--r-- | lib/string_helpers.c | 8 | ||||
| -rw-r--r-- | lib/strncpy_from_user.c | 113 | ||||
| -rw-r--r-- | lib/strnlen_user.c | 138 | ||||
| -rw-r--r-- | lib/swiotlb.c | 8 | ||||
| -rw-r--r-- | lib/test-kstrtox.c | 4 | ||||
| -rw-r--r-- | lib/vsprintf.c | 303 |
15 files changed, 598 insertions, 130 deletions
diff --git a/lib/Kconfig b/lib/Kconfig index 0e25c03939e3..a9e15403434e 100644 --- a/lib/Kconfig +++ b/lib/Kconfig | |||
| @@ -16,6 +16,12 @@ config BITREVERSE | |||
| 16 | config RATIONAL | 16 | config RATIONAL |
| 17 | boolean | 17 | boolean |
| 18 | 18 | ||
| 19 | config GENERIC_STRNCPY_FROM_USER | ||
| 20 | bool | ||
| 21 | |||
| 22 | config GENERIC_STRNLEN_USER | ||
| 23 | bool | ||
| 24 | |||
| 19 | config GENERIC_FIND_FIRST_BIT | 25 | config GENERIC_FIND_FIRST_BIT |
| 20 | bool | 26 | bool |
| 21 | 27 | ||
| @@ -33,6 +39,9 @@ config GENERIC_IO | |||
| 33 | boolean | 39 | boolean |
| 34 | default n | 40 | default n |
| 35 | 41 | ||
| 42 | config STMP_DEVICE | ||
| 43 | bool | ||
| 44 | |||
| 36 | config CRC_CCITT | 45 | config CRC_CCITT |
| 37 | tristate "CRC-CCITT functions" | 46 | tristate "CRC-CCITT functions" |
| 38 | help | 47 | help |
diff --git a/lib/Makefile b/lib/Makefile index 74290c9e2864..8c31a0cb75e9 100644 --- a/lib/Makefile +++ b/lib/Makefile | |||
| @@ -125,6 +125,11 @@ obj-$(CONFIG_CLZ_TAB) += clz_tab.o | |||
| 125 | 125 | ||
| 126 | obj-$(CONFIG_DDR) += jedec_ddr_data.o | 126 | obj-$(CONFIG_DDR) += jedec_ddr_data.o |
| 127 | 127 | ||
| 128 | obj-$(CONFIG_GENERIC_STRNCPY_FROM_USER) += strncpy_from_user.o | ||
| 129 | obj-$(CONFIG_GENERIC_STRNLEN_USER) += strnlen_user.o | ||
| 130 | |||
| 131 | obj-$(CONFIG_STMP_DEVICE) += stmp_device.o | ||
| 132 | |||
| 128 | hostprogs-y := gen_crc32table | 133 | hostprogs-y := gen_crc32table |
| 129 | clean-files := crc32table.h | 134 | clean-files := crc32table.h |
| 130 | 135 | ||
diff --git a/lib/bitmap.c b/lib/bitmap.c index b5a8b6ad2454..06fdfa1aeba7 100644 --- a/lib/bitmap.c +++ b/lib/bitmap.c | |||
| @@ -369,7 +369,8 @@ EXPORT_SYMBOL(bitmap_find_next_zero_area); | |||
| 369 | * @nmaskbits: size of bitmap, in bits | 369 | * @nmaskbits: size of bitmap, in bits |
| 370 | * | 370 | * |
| 371 | * Exactly @nmaskbits bits are displayed. Hex digits are grouped into | 371 | * Exactly @nmaskbits bits are displayed. Hex digits are grouped into |
| 372 | * comma-separated sets of eight digits per set. | 372 | * comma-separated sets of eight digits per set. Returns the number of |
| 373 | * characters which were written to *buf, excluding the trailing \0. | ||
| 373 | */ | 374 | */ |
| 374 | int bitmap_scnprintf(char *buf, unsigned int buflen, | 375 | int bitmap_scnprintf(char *buf, unsigned int buflen, |
| 375 | const unsigned long *maskp, int nmaskbits) | 376 | const unsigned long *maskp, int nmaskbits) |
| @@ -517,8 +518,8 @@ EXPORT_SYMBOL(bitmap_parse_user); | |||
| 517 | * | 518 | * |
| 518 | * Helper routine for bitmap_scnlistprintf(). Write decimal number | 519 | * Helper routine for bitmap_scnlistprintf(). Write decimal number |
| 519 | * or range to buf, suppressing output past buf+buflen, with optional | 520 | * or range to buf, suppressing output past buf+buflen, with optional |
| 520 | * comma-prefix. Return len of what would be written to buf, if it | 521 | * comma-prefix. Return len of what was written to *buf, excluding the |
| 521 | * all fit. | 522 | * trailing \0. |
| 522 | */ | 523 | */ |
| 523 | static inline int bscnl_emit(char *buf, int buflen, int rbot, int rtop, int len) | 524 | static inline int bscnl_emit(char *buf, int buflen, int rbot, int rtop, int len) |
| 524 | { | 525 | { |
| @@ -544,9 +545,8 @@ static inline int bscnl_emit(char *buf, int buflen, int rbot, int rtop, int len) | |||
| 544 | * the range. Output format is compatible with the format | 545 | * the range. Output format is compatible with the format |
| 545 | * accepted as input by bitmap_parselist(). | 546 | * accepted as input by bitmap_parselist(). |
| 546 | * | 547 | * |
| 547 | * The return value is the number of characters which would be | 548 | * The return value is the number of characters which were written to *buf |
| 548 | * generated for the given input, excluding the trailing '\0', as | 549 | * excluding the trailing '\0', as per ISO C99's scnprintf. |
| 549 | * per ISO C99. | ||
| 550 | */ | 550 | */ |
| 551 | int bitmap_scnlistprintf(char *buf, unsigned int buflen, | 551 | int bitmap_scnlistprintf(char *buf, unsigned int buflen, |
| 552 | const unsigned long *maskp, int nmaskbits) | 552 | const unsigned long *maskp, int nmaskbits) |
diff --git a/lib/dma-debug.c b/lib/dma-debug.c index 13ef2338be41..518aea714d21 100644 --- a/lib/dma-debug.c +++ b/lib/dma-debug.c | |||
| @@ -430,7 +430,7 @@ static struct dma_debug_entry *__dma_entry_alloc(void) | |||
| 430 | */ | 430 | */ |
| 431 | static struct dma_debug_entry *dma_entry_alloc(void) | 431 | static struct dma_debug_entry *dma_entry_alloc(void) |
| 432 | { | 432 | { |
| 433 | struct dma_debug_entry *entry = NULL; | 433 | struct dma_debug_entry *entry; |
| 434 | unsigned long flags; | 434 | unsigned long flags; |
| 435 | 435 | ||
| 436 | spin_lock_irqsave(&free_entries_lock, flags); | 436 | spin_lock_irqsave(&free_entries_lock, flags); |
| @@ -438,11 +438,14 @@ static struct dma_debug_entry *dma_entry_alloc(void) | |||
| 438 | if (list_empty(&free_entries)) { | 438 | if (list_empty(&free_entries)) { |
| 439 | pr_err("DMA-API: debugging out of memory - disabling\n"); | 439 | pr_err("DMA-API: debugging out of memory - disabling\n"); |
| 440 | global_disable = true; | 440 | global_disable = true; |
| 441 | goto out; | 441 | spin_unlock_irqrestore(&free_entries_lock, flags); |
| 442 | return NULL; | ||
| 442 | } | 443 | } |
| 443 | 444 | ||
| 444 | entry = __dma_entry_alloc(); | 445 | entry = __dma_entry_alloc(); |
| 445 | 446 | ||
| 447 | spin_unlock_irqrestore(&free_entries_lock, flags); | ||
| 448 | |||
| 446 | #ifdef CONFIG_STACKTRACE | 449 | #ifdef CONFIG_STACKTRACE |
| 447 | entry->stacktrace.max_entries = DMA_DEBUG_STACKTRACE_ENTRIES; | 450 | entry->stacktrace.max_entries = DMA_DEBUG_STACKTRACE_ENTRIES; |
| 448 | entry->stacktrace.entries = entry->st_entries; | 451 | entry->stacktrace.entries = entry->st_entries; |
| @@ -450,9 +453,6 @@ static struct dma_debug_entry *dma_entry_alloc(void) | |||
| 450 | save_stack_trace(&entry->stacktrace); | 453 | save_stack_trace(&entry->stacktrace); |
| 451 | #endif | 454 | #endif |
| 452 | 455 | ||
| 453 | out: | ||
| 454 | spin_unlock_irqrestore(&free_entries_lock, flags); | ||
| 455 | |||
| 456 | return entry; | 456 | return entry; |
| 457 | } | 457 | } |
| 458 | 458 | ||
diff --git a/lib/dynamic_queue_limits.c b/lib/dynamic_queue_limits.c index 6ab4587d052b..0777c5a45fa0 100644 --- a/lib/dynamic_queue_limits.c +++ b/lib/dynamic_queue_limits.c | |||
| @@ -10,23 +10,27 @@ | |||
| 10 | #include <linux/jiffies.h> | 10 | #include <linux/jiffies.h> |
| 11 | #include <linux/dynamic_queue_limits.h> | 11 | #include <linux/dynamic_queue_limits.h> |
| 12 | 12 | ||
| 13 | #define POSDIFF(A, B) ((A) > (B) ? (A) - (B) : 0) | 13 | #define POSDIFF(A, B) ((int)((A) - (B)) > 0 ? (A) - (B) : 0) |
| 14 | #define AFTER_EQ(A, B) ((int)((A) - (B)) >= 0) | ||
| 14 | 15 | ||
| 15 | /* Records completed count and recalculates the queue limit */ | 16 | /* Records completed count and recalculates the queue limit */ |
| 16 | void dql_completed(struct dql *dql, unsigned int count) | 17 | void dql_completed(struct dql *dql, unsigned int count) |
| 17 | { | 18 | { |
| 18 | unsigned int inprogress, prev_inprogress, limit; | 19 | unsigned int inprogress, prev_inprogress, limit; |
| 19 | unsigned int ovlimit, all_prev_completed, completed; | 20 | unsigned int ovlimit, completed, num_queued; |
| 21 | bool all_prev_completed; | ||
| 22 | |||
| 23 | num_queued = ACCESS_ONCE(dql->num_queued); | ||
| 20 | 24 | ||
| 21 | /* Can't complete more than what's in queue */ | 25 | /* Can't complete more than what's in queue */ |
| 22 | BUG_ON(count > dql->num_queued - dql->num_completed); | 26 | BUG_ON(count > num_queued - dql->num_completed); |
| 23 | 27 | ||
| 24 | completed = dql->num_completed + count; | 28 | completed = dql->num_completed + count; |
| 25 | limit = dql->limit; | 29 | limit = dql->limit; |
| 26 | ovlimit = POSDIFF(dql->num_queued - dql->num_completed, limit); | 30 | ovlimit = POSDIFF(num_queued - dql->num_completed, limit); |
| 27 | inprogress = dql->num_queued - completed; | 31 | inprogress = num_queued - completed; |
| 28 | prev_inprogress = dql->prev_num_queued - dql->num_completed; | 32 | prev_inprogress = dql->prev_num_queued - dql->num_completed; |
| 29 | all_prev_completed = POSDIFF(completed, dql->prev_num_queued); | 33 | all_prev_completed = AFTER_EQ(completed, dql->prev_num_queued); |
| 30 | 34 | ||
| 31 | if ((ovlimit && !inprogress) || | 35 | if ((ovlimit && !inprogress) || |
| 32 | (dql->prev_ovlimit && all_prev_completed)) { | 36 | (dql->prev_ovlimit && all_prev_completed)) { |
| @@ -104,7 +108,7 @@ void dql_completed(struct dql *dql, unsigned int count) | |||
| 104 | dql->prev_ovlimit = ovlimit; | 108 | dql->prev_ovlimit = ovlimit; |
| 105 | dql->prev_last_obj_cnt = dql->last_obj_cnt; | 109 | dql->prev_last_obj_cnt = dql->last_obj_cnt; |
| 106 | dql->num_completed = completed; | 110 | dql->num_completed = completed; |
| 107 | dql->prev_num_queued = dql->num_queued; | 111 | dql->prev_num_queued = num_queued; |
| 108 | } | 112 | } |
| 109 | EXPORT_SYMBOL(dql_completed); | 113 | EXPORT_SYMBOL(dql_completed); |
| 110 | 114 | ||
diff --git a/lib/list_debug.c b/lib/list_debug.c index 3810b481f940..23a5e031cd8b 100644 --- a/lib/list_debug.c +++ b/lib/list_debug.c | |||
| @@ -31,6 +31,9 @@ void __list_add(struct list_head *new, | |||
| 31 | "list_add corruption. prev->next should be " | 31 | "list_add corruption. prev->next should be " |
| 32 | "next (%p), but was %p. (prev=%p).\n", | 32 | "next (%p), but was %p. (prev=%p).\n", |
| 33 | next, prev->next, prev); | 33 | next, prev->next, prev); |
| 34 | WARN(new == prev || new == next, | ||
| 35 | "list_add double add: new=%p, prev=%p, next=%p.\n", | ||
| 36 | new, prev, next); | ||
| 34 | next->prev = new; | 37 | next->prev = new; |
| 35 | new->next = next; | 38 | new->next = next; |
| 36 | new->prev = prev; | 39 | new->prev = prev; |
diff --git a/lib/radix-tree.c b/lib/radix-tree.c index 86516f5588e3..d7c878cc006c 100644 --- a/lib/radix-tree.c +++ b/lib/radix-tree.c | |||
| @@ -73,11 +73,24 @@ static unsigned long height_to_maxindex[RADIX_TREE_MAX_PATH + 1] __read_mostly; | |||
| 73 | static struct kmem_cache *radix_tree_node_cachep; | 73 | static struct kmem_cache *radix_tree_node_cachep; |
| 74 | 74 | ||
| 75 | /* | 75 | /* |
| 76 | * The radix tree is variable-height, so an insert operation not only has | ||
| 77 | * to build the branch to its corresponding item, it also has to build the | ||
| 78 | * branch to existing items if the size has to be increased (by | ||
| 79 | * radix_tree_extend). | ||
| 80 | * | ||
| 81 | * The worst case is a zero height tree with just a single item at index 0, | ||
| 82 | * and then inserting an item at index ULONG_MAX. This requires 2 new branches | ||
| 83 | * of RADIX_TREE_MAX_PATH size to be created, with only the root node shared. | ||
| 84 | * Hence: | ||
| 85 | */ | ||
| 86 | #define RADIX_TREE_PRELOAD_SIZE (RADIX_TREE_MAX_PATH * 2 - 1) | ||
| 87 | |||
| 88 | /* | ||
| 76 | * Per-cpu pool of preloaded nodes | 89 | * Per-cpu pool of preloaded nodes |
| 77 | */ | 90 | */ |
| 78 | struct radix_tree_preload { | 91 | struct radix_tree_preload { |
| 79 | int nr; | 92 | int nr; |
| 80 | struct radix_tree_node *nodes[RADIX_TREE_MAX_PATH]; | 93 | struct radix_tree_node *nodes[RADIX_TREE_PRELOAD_SIZE]; |
| 81 | }; | 94 | }; |
| 82 | static DEFINE_PER_CPU(struct radix_tree_preload, radix_tree_preloads) = { 0, }; | 95 | static DEFINE_PER_CPU(struct radix_tree_preload, radix_tree_preloads) = { 0, }; |
| 83 | 96 | ||
diff --git a/lib/spinlock_debug.c b/lib/spinlock_debug.c index 525d160d44f0..d0ec4f3d1593 100644 --- a/lib/spinlock_debug.c +++ b/lib/spinlock_debug.c | |||
| @@ -58,7 +58,7 @@ static void spin_dump(raw_spinlock_t *lock, const char *msg) | |||
| 58 | printk(KERN_EMERG "BUG: spinlock %s on CPU#%d, %s/%d\n", | 58 | printk(KERN_EMERG "BUG: spinlock %s on CPU#%d, %s/%d\n", |
| 59 | msg, raw_smp_processor_id(), | 59 | msg, raw_smp_processor_id(), |
| 60 | current->comm, task_pid_nr(current)); | 60 | current->comm, task_pid_nr(current)); |
| 61 | printk(KERN_EMERG " lock: %p, .magic: %08x, .owner: %s/%d, " | 61 | printk(KERN_EMERG " lock: %ps, .magic: %08x, .owner: %s/%d, " |
| 62 | ".owner_cpu: %d\n", | 62 | ".owner_cpu: %d\n", |
| 63 | lock, lock->magic, | 63 | lock, lock->magic, |
| 64 | owner ? owner->comm : "<none>", | 64 | owner ? owner->comm : "<none>", |
diff --git a/lib/stmp_device.c b/lib/stmp_device.c new file mode 100644 index 000000000000..8ac9bcc4289a --- /dev/null +++ b/lib/stmp_device.c | |||
| @@ -0,0 +1,80 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 1999 ARM Limited | ||
| 3 | * Copyright (C) 2000 Deep Blue Solutions Ltd | ||
| 4 | * Copyright 2006-2007,2010 Freescale Semiconductor, Inc. All Rights Reserved. | ||
| 5 | * Copyright 2008 Juergen Beisert, kernel@pengutronix.de | ||
| 6 | * Copyright 2009 Ilya Yanok, Emcraft Systems Ltd, yanok@emcraft.com | ||
| 7 | * Copyright (C) 2011 Wolfram Sang, Pengutronix e.K. | ||
| 8 | * | ||
| 9 | * This program is free software; you can redistribute it and/or modify | ||
| 10 | * it under the terms of the GNU General Public License as published by | ||
| 11 | * the Free Software Foundation; either version 2 of the License, or | ||
| 12 | * (at your option) any later version. | ||
| 13 | */ | ||
| 14 | |||
| 15 | #include <linux/io.h> | ||
| 16 | #include <linux/errno.h> | ||
| 17 | #include <linux/delay.h> | ||
| 18 | #include <linux/module.h> | ||
| 19 | #include <linux/stmp_device.h> | ||
| 20 | |||
| 21 | #define STMP_MODULE_CLKGATE (1 << 30) | ||
| 22 | #define STMP_MODULE_SFTRST (1 << 31) | ||
| 23 | |||
| 24 | /* | ||
| 25 | * Clear the bit and poll it cleared. This is usually called with | ||
| 26 | * a reset address and mask being either SFTRST(bit 31) or CLKGATE | ||
| 27 | * (bit 30). | ||
| 28 | */ | ||
| 29 | static int stmp_clear_poll_bit(void __iomem *addr, u32 mask) | ||
| 30 | { | ||
| 31 | int timeout = 0x400; | ||
| 32 | |||
| 33 | writel(mask, addr + STMP_OFFSET_REG_CLR); | ||
| 34 | udelay(1); | ||
| 35 | while ((readl(addr) & mask) && --timeout) | ||
| 36 | /* nothing */; | ||
| 37 | |||
| 38 | return !timeout; | ||
| 39 | } | ||
| 40 | |||
| 41 | int stmp_reset_block(void __iomem *reset_addr) | ||
| 42 | { | ||
| 43 | int ret; | ||
| 44 | int timeout = 0x400; | ||
| 45 | |||
| 46 | /* clear and poll SFTRST */ | ||
| 47 | ret = stmp_clear_poll_bit(reset_addr, STMP_MODULE_SFTRST); | ||
| 48 | if (unlikely(ret)) | ||
| 49 | goto error; | ||
| 50 | |||
| 51 | /* clear CLKGATE */ | ||
| 52 | writel(STMP_MODULE_CLKGATE, reset_addr + STMP_OFFSET_REG_CLR); | ||
| 53 | |||
| 54 | /* set SFTRST to reset the block */ | ||
| 55 | writel(STMP_MODULE_SFTRST, reset_addr + STMP_OFFSET_REG_SET); | ||
| 56 | udelay(1); | ||
| 57 | |||
| 58 | /* poll CLKGATE becoming set */ | ||
| 59 | while ((!(readl(reset_addr) & STMP_MODULE_CLKGATE)) && --timeout) | ||
| 60 | /* nothing */; | ||
| 61 | if (unlikely(!timeout)) | ||
| 62 | goto error; | ||
| 63 | |||
| 64 | /* clear and poll SFTRST */ | ||
| 65 | ret = stmp_clear_poll_bit(reset_addr, STMP_MODULE_SFTRST); | ||
| 66 | if (unlikely(ret)) | ||
| 67 | goto error; | ||
| 68 | |||
| 69 | /* clear and poll CLKGATE */ | ||
| 70 | ret = stmp_clear_poll_bit(reset_addr, STMP_MODULE_CLKGATE); | ||
| 71 | if (unlikely(ret)) | ||
| 72 | goto error; | ||
| 73 | |||
| 74 | return 0; | ||
| 75 | |||
| 76 | error: | ||
| 77 | pr_err("%s(%p): module reset timeout\n", __func__, reset_addr); | ||
| 78 | return -ETIMEDOUT; | ||
| 79 | } | ||
| 80 | EXPORT_SYMBOL(stmp_reset_block); | ||
diff --git a/lib/string_helpers.c b/lib/string_helpers.c index dd4ece372699..1cffc223bff5 100644 --- a/lib/string_helpers.c +++ b/lib/string_helpers.c | |||
| @@ -23,15 +23,15 @@ | |||
| 23 | int string_get_size(u64 size, const enum string_size_units units, | 23 | int string_get_size(u64 size, const enum string_size_units units, |
| 24 | char *buf, int len) | 24 | char *buf, int len) |
| 25 | { | 25 | { |
| 26 | const char *units_10[] = { "B", "kB", "MB", "GB", "TB", "PB", | 26 | static const char *units_10[] = { "B", "kB", "MB", "GB", "TB", "PB", |
| 27 | "EB", "ZB", "YB", NULL}; | 27 | "EB", "ZB", "YB", NULL}; |
| 28 | const char *units_2[] = {"B", "KiB", "MiB", "GiB", "TiB", "PiB", | 28 | static const char *units_2[] = {"B", "KiB", "MiB", "GiB", "TiB", "PiB", |
| 29 | "EiB", "ZiB", "YiB", NULL }; | 29 | "EiB", "ZiB", "YiB", NULL }; |
| 30 | const char **units_str[] = { | 30 | static const char **units_str[] = { |
| 31 | [STRING_UNITS_10] = units_10, | 31 | [STRING_UNITS_10] = units_10, |
| 32 | [STRING_UNITS_2] = units_2, | 32 | [STRING_UNITS_2] = units_2, |
| 33 | }; | 33 | }; |
| 34 | const unsigned int divisor[] = { | 34 | static const unsigned int divisor[] = { |
| 35 | [STRING_UNITS_10] = 1000, | 35 | [STRING_UNITS_10] = 1000, |
| 36 | [STRING_UNITS_2] = 1024, | 36 | [STRING_UNITS_2] = 1024, |
| 37 | }; | 37 | }; |
diff --git a/lib/strncpy_from_user.c b/lib/strncpy_from_user.c new file mode 100644 index 000000000000..bb2b201d6ad0 --- /dev/null +++ b/lib/strncpy_from_user.c | |||
| @@ -0,0 +1,113 @@ | |||
| 1 | #include <linux/module.h> | ||
| 2 | #include <linux/uaccess.h> | ||
| 3 | #include <linux/kernel.h> | ||
| 4 | #include <linux/errno.h> | ||
| 5 | |||
| 6 | #include <asm/byteorder.h> | ||
| 7 | #include <asm/word-at-a-time.h> | ||
| 8 | |||
| 9 | #ifdef CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS | ||
| 10 | #define IS_UNALIGNED(src, dst) 0 | ||
| 11 | #else | ||
| 12 | #define IS_UNALIGNED(src, dst) \ | ||
| 13 | (((long) dst | (long) src) & (sizeof(long) - 1)) | ||
| 14 | #endif | ||
| 15 | |||
| 16 | /* | ||
| 17 | * Do a strncpy, return length of string without final '\0'. | ||
| 18 | * 'count' is the user-supplied count (return 'count' if we | ||
| 19 | * hit it), 'max' is the address space maximum (and we return | ||
| 20 | * -EFAULT if we hit it). | ||
| 21 | */ | ||
| 22 | static inline long do_strncpy_from_user(char *dst, const char __user *src, long count, unsigned long max) | ||
| 23 | { | ||
| 24 | const struct word_at_a_time constants = WORD_AT_A_TIME_CONSTANTS; | ||
| 25 | long res = 0; | ||
| 26 | |||
| 27 | /* | ||
| 28 | * Truncate 'max' to the user-specified limit, so that | ||
| 29 | * we only have one limit we need to check in the loop | ||
| 30 | */ | ||
| 31 | if (max > count) | ||
| 32 | max = count; | ||
| 33 | |||
| 34 | if (IS_UNALIGNED(src, dst)) | ||
| 35 | goto byte_at_a_time; | ||
| 36 | |||
| 37 | while (max >= sizeof(unsigned long)) { | ||
| 38 | unsigned long c, data; | ||
| 39 | |||
| 40 | /* Fall back to byte-at-a-time if we get a page fault */ | ||
| 41 | if (unlikely(__get_user(c,(unsigned long __user *)(src+res)))) | ||
| 42 | break; | ||
| 43 | *(unsigned long *)(dst+res) = c; | ||
| 44 | if (has_zero(c, &data, &constants)) { | ||
| 45 | data = prep_zero_mask(c, data, &constants); | ||
| 46 | data = create_zero_mask(data); | ||
| 47 | return res + find_zero(data); | ||
| 48 | } | ||
| 49 | res += sizeof(unsigned long); | ||
| 50 | max -= sizeof(unsigned long); | ||
| 51 | } | ||
| 52 | |||
| 53 | byte_at_a_time: | ||
| 54 | while (max) { | ||
| 55 | char c; | ||
| 56 | |||
| 57 | if (unlikely(__get_user(c,src+res))) | ||
| 58 | return -EFAULT; | ||
| 59 | dst[res] = c; | ||
| 60 | if (!c) | ||
| 61 | return res; | ||
| 62 | res++; | ||
| 63 | max--; | ||
| 64 | } | ||
| 65 | |||
| 66 | /* | ||
| 67 | * Uhhuh. We hit 'max'. But was that the user-specified maximum | ||
| 68 | * too? If so, that's ok - we got as much as the user asked for. | ||
| 69 | */ | ||
| 70 | if (res >= count) | ||
| 71 | return res; | ||
| 72 | |||
| 73 | /* | ||
| 74 | * Nope: we hit the address space limit, and we still had more | ||
| 75 | * characters the caller would have wanted. That's an EFAULT. | ||
| 76 | */ | ||
| 77 | return -EFAULT; | ||
| 78 | } | ||
| 79 | |||
| 80 | /** | ||
| 81 | * strncpy_from_user: - Copy a NUL terminated string from userspace. | ||
| 82 | * @dst: Destination address, in kernel space. This buffer must be at | ||
| 83 | * least @count bytes long. | ||
| 84 | * @src: Source address, in user space. | ||
| 85 | * @count: Maximum number of bytes to copy, including the trailing NUL. | ||
| 86 | * | ||
| 87 | * Copies a NUL-terminated string from userspace to kernel space. | ||
| 88 | * | ||
| 89 | * On success, returns the length of the string (not including the trailing | ||
| 90 | * NUL). | ||
| 91 | * | ||
| 92 | * If access to userspace fails, returns -EFAULT (some data may have been | ||
| 93 | * copied). | ||
| 94 | * | ||
| 95 | * If @count is smaller than the length of the string, copies @count bytes | ||
| 96 | * and returns @count. | ||
| 97 | */ | ||
| 98 | long strncpy_from_user(char *dst, const char __user *src, long count) | ||
| 99 | { | ||
| 100 | unsigned long max_addr, src_addr; | ||
| 101 | |||
| 102 | if (unlikely(count <= 0)) | ||
| 103 | return 0; | ||
| 104 | |||
| 105 | max_addr = user_addr_max(); | ||
| 106 | src_addr = (unsigned long)src; | ||
| 107 | if (likely(src_addr < max_addr)) { | ||
| 108 | unsigned long max = max_addr - src_addr; | ||
| 109 | return do_strncpy_from_user(dst, src, count, max); | ||
| 110 | } | ||
| 111 | return -EFAULT; | ||
| 112 | } | ||
| 113 | EXPORT_SYMBOL(strncpy_from_user); | ||
diff --git a/lib/strnlen_user.c b/lib/strnlen_user.c new file mode 100644 index 000000000000..a28df5206d95 --- /dev/null +++ b/lib/strnlen_user.c | |||
| @@ -0,0 +1,138 @@ | |||
| 1 | #include <linux/kernel.h> | ||
| 2 | #include <linux/export.h> | ||
| 3 | #include <linux/uaccess.h> | ||
| 4 | |||
| 5 | #include <asm/word-at-a-time.h> | ||
| 6 | |||
| 7 | /* Set bits in the first 'n' bytes when loaded from memory */ | ||
| 8 | #ifdef __LITTLE_ENDIAN | ||
| 9 | # define aligned_byte_mask(n) ((1ul << 8*(n))-1) | ||
| 10 | #else | ||
| 11 | # define aligned_byte_mask(n) (~0xfful << (BITS_PER_LONG - 8 - 8*(n))) | ||
| 12 | #endif | ||
| 13 | |||
| 14 | /* | ||
| 15 | * Do a strnlen, return length of string *with* final '\0'. | ||
| 16 | * 'count' is the user-supplied count, while 'max' is the | ||
| 17 | * address space maximum. | ||
| 18 | * | ||
| 19 | * Return 0 for exceptions (which includes hitting the address | ||
| 20 | * space maximum), or 'count+1' if hitting the user-supplied | ||
| 21 | * maximum count. | ||
| 22 | * | ||
| 23 | * NOTE! We can sometimes overshoot the user-supplied maximum | ||
| 24 | * if it fits in a aligned 'long'. The caller needs to check | ||
| 25 | * the return value against "> max". | ||
| 26 | */ | ||
| 27 | static inline long do_strnlen_user(const char __user *src, unsigned long count, unsigned long max) | ||
| 28 | { | ||
| 29 | const struct word_at_a_time constants = WORD_AT_A_TIME_CONSTANTS; | ||
| 30 | long align, res = 0; | ||
| 31 | unsigned long c; | ||
| 32 | |||
| 33 | /* | ||
| 34 | * Truncate 'max' to the user-specified limit, so that | ||
| 35 | * we only have one limit we need to check in the loop | ||
| 36 | */ | ||
| 37 | if (max > count) | ||
| 38 | max = count; | ||
| 39 | |||
| 40 | /* | ||
| 41 | * Do everything aligned. But that means that we | ||
| 42 | * need to also expand the maximum.. | ||
| 43 | */ | ||
| 44 | align = (sizeof(long) - 1) & (unsigned long)src; | ||
| 45 | src -= align; | ||
| 46 | max += align; | ||
| 47 | |||
| 48 | if (unlikely(__get_user(c,(unsigned long __user *)src))) | ||
| 49 | return 0; | ||
| 50 | c |= aligned_byte_mask(align); | ||
| 51 | |||
| 52 | for (;;) { | ||
| 53 | unsigned long data; | ||
| 54 | if (has_zero(c, &data, &constants)) { | ||
| 55 | data = prep_zero_mask(c, data, &constants); | ||
| 56 | data = create_zero_mask(data); | ||
| 57 | return res + find_zero(data) + 1 - align; | ||
| 58 | } | ||
| 59 | res += sizeof(unsigned long); | ||
| 60 | if (unlikely(max < sizeof(unsigned long))) | ||
| 61 | break; | ||
| 62 | max -= sizeof(unsigned long); | ||
| 63 | if (unlikely(__get_user(c,(unsigned long __user *)(src+res)))) | ||
| 64 | return 0; | ||
| 65 | } | ||
| 66 | res -= align; | ||
| 67 | |||
| 68 | /* | ||
| 69 | * Uhhuh. We hit 'max'. But was that the user-specified maximum | ||
| 70 | * too? If so, return the marker for "too long". | ||
| 71 | */ | ||
| 72 | if (res >= count) | ||
| 73 | return count+1; | ||
| 74 | |||
| 75 | /* | ||
| 76 | * Nope: we hit the address space limit, and we still had more | ||
| 77 | * characters the caller would have wanted. That's 0. | ||
| 78 | */ | ||
| 79 | return 0; | ||
| 80 | } | ||
| 81 | |||
| 82 | /** | ||
| 83 | * strnlen_user: - Get the size of a user string INCLUDING final NUL. | ||
| 84 | * @str: The string to measure. | ||
| 85 | * @count: Maximum count (including NUL character) | ||
| 86 | * | ||
| 87 | * Context: User context only. This function may sleep. | ||
| 88 | * | ||
| 89 | * Get the size of a NUL-terminated string in user space. | ||
| 90 | * | ||
| 91 | * Returns the size of the string INCLUDING the terminating NUL. | ||
| 92 | * If the string is too long, returns 'count+1'. | ||
| 93 | * On exception (or invalid count), returns 0. | ||
| 94 | */ | ||
| 95 | long strnlen_user(const char __user *str, long count) | ||
| 96 | { | ||
| 97 | unsigned long max_addr, src_addr; | ||
| 98 | |||
| 99 | if (unlikely(count <= 0)) | ||
| 100 | return 0; | ||
| 101 | |||
| 102 | max_addr = user_addr_max(); | ||
| 103 | src_addr = (unsigned long)str; | ||
| 104 | if (likely(src_addr < max_addr)) { | ||
| 105 | unsigned long max = max_addr - src_addr; | ||
| 106 | return do_strnlen_user(str, count, max); | ||
| 107 | } | ||
| 108 | return 0; | ||
| 109 | } | ||
| 110 | EXPORT_SYMBOL(strnlen_user); | ||
| 111 | |||
| 112 | /** | ||
| 113 | * strlen_user: - Get the size of a user string INCLUDING final NUL. | ||
| 114 | * @str: The string to measure. | ||
| 115 | * | ||
| 116 | * Context: User context only. This function may sleep. | ||
| 117 | * | ||
| 118 | * Get the size of a NUL-terminated string in user space. | ||
| 119 | * | ||
| 120 | * Returns the size of the string INCLUDING the terminating NUL. | ||
| 121 | * On exception, returns 0. | ||
| 122 | * | ||
| 123 | * If there is a limit on the length of a valid string, you may wish to | ||
| 124 | * consider using strnlen_user() instead. | ||
| 125 | */ | ||
| 126 | long strlen_user(const char __user *str) | ||
| 127 | { | ||
| 128 | unsigned long max_addr, src_addr; | ||
| 129 | |||
| 130 | max_addr = user_addr_max(); | ||
| 131 | src_addr = (unsigned long)str; | ||
| 132 | if (likely(src_addr < max_addr)) { | ||
| 133 | unsigned long max = max_addr - src_addr; | ||
| 134 | return do_strnlen_user(str, ~0ul, max); | ||
| 135 | } | ||
| 136 | return 0; | ||
| 137 | } | ||
| 138 | EXPORT_SYMBOL(strlen_user); | ||
diff --git a/lib/swiotlb.c b/lib/swiotlb.c index 414f46ed1dcd..45bc1f83a5ad 100644 --- a/lib/swiotlb.c +++ b/lib/swiotlb.c | |||
| @@ -130,11 +130,9 @@ void swiotlb_print_info(void) | |||
| 130 | pstart = virt_to_phys(io_tlb_start); | 130 | pstart = virt_to_phys(io_tlb_start); |
| 131 | pend = virt_to_phys(io_tlb_end); | 131 | pend = virt_to_phys(io_tlb_end); |
| 132 | 132 | ||
| 133 | printk(KERN_INFO "Placing %luMB software IO TLB between %p - %p\n", | 133 | printk(KERN_INFO "software IO TLB [mem %#010llx-%#010llx] (%luMB) mapped at [%p-%p]\n", |
| 134 | bytes >> 20, io_tlb_start, io_tlb_end); | 134 | (unsigned long long)pstart, (unsigned long long)pend - 1, |
| 135 | printk(KERN_INFO "software IO TLB at phys %#llx - %#llx\n", | 135 | bytes >> 20, io_tlb_start, io_tlb_end - 1); |
| 136 | (unsigned long long)pstart, | ||
| 137 | (unsigned long long)pend); | ||
| 138 | } | 136 | } |
| 139 | 137 | ||
| 140 | void __init swiotlb_init_with_tbl(char *tlb, unsigned long nslabs, int verbose) | 138 | void __init swiotlb_init_with_tbl(char *tlb, unsigned long nslabs, int verbose) |
diff --git a/lib/test-kstrtox.c b/lib/test-kstrtox.c index d55769d63cb8..bea3f3fa3f02 100644 --- a/lib/test-kstrtox.c +++ b/lib/test-kstrtox.c | |||
| @@ -11,7 +11,7 @@ struct test_fail { | |||
| 11 | }; | 11 | }; |
| 12 | 12 | ||
| 13 | #define DEFINE_TEST_FAIL(test) \ | 13 | #define DEFINE_TEST_FAIL(test) \ |
| 14 | const struct test_fail test[] __initdata | 14 | const struct test_fail test[] __initconst |
| 15 | 15 | ||
| 16 | #define DECLARE_TEST_OK(type, test_type) \ | 16 | #define DECLARE_TEST_OK(type, test_type) \ |
| 17 | test_type { \ | 17 | test_type { \ |
| @@ -21,7 +21,7 @@ struct test_fail { | |||
| 21 | } | 21 | } |
| 22 | 22 | ||
| 23 | #define DEFINE_TEST_OK(type, test) \ | 23 | #define DEFINE_TEST_OK(type, test) \ |
| 24 | const type test[] __initdata | 24 | const type test[] __initconst |
| 25 | 25 | ||
| 26 | #define TEST_FAIL(fn, type, fmt, test) \ | 26 | #define TEST_FAIL(fn, type, fmt, test) \ |
| 27 | { \ | 27 | { \ |
diff --git a/lib/vsprintf.c b/lib/vsprintf.c index abbabec9720a..c3f36d415bdf 100644 --- a/lib/vsprintf.c +++ b/lib/vsprintf.c | |||
| @@ -112,106 +112,199 @@ int skip_atoi(const char **s) | |||
| 112 | /* Decimal conversion is by far the most typical, and is used | 112 | /* Decimal conversion is by far the most typical, and is used |
| 113 | * for /proc and /sys data. This directly impacts e.g. top performance | 113 | * for /proc and /sys data. This directly impacts e.g. top performance |
| 114 | * with many processes running. We optimize it for speed | 114 | * with many processes running. We optimize it for speed |
| 115 | * using code from | 115 | * using ideas described at <http://www.cs.uiowa.edu/~jones/bcd/divide.html> |
| 116 | * http://www.cs.uiowa.edu/~jones/bcd/decimal.html | 116 | * (with permission from the author, Douglas W. Jones). |
| 117 | * (with permission from the author, Douglas W. Jones). */ | 117 | */ |
| 118 | 118 | ||
| 119 | /* Formats correctly any integer in [0,99999]. | 119 | #if BITS_PER_LONG != 32 || BITS_PER_LONG_LONG != 64 |
| 120 | * Outputs from one to five digits depending on input. | 120 | /* Formats correctly any integer in [0, 999999999] */ |
| 121 | * On i386 gcc 4.1.2 -O2: ~250 bytes of code. */ | ||
| 122 | static noinline_for_stack | 121 | static noinline_for_stack |
| 123 | char *put_dec_trunc(char *buf, unsigned q) | 122 | char *put_dec_full9(char *buf, unsigned q) |
| 124 | { | 123 | { |
| 125 | unsigned d3, d2, d1, d0; | 124 | unsigned r; |
| 126 | d1 = (q>>4) & 0xf; | ||
| 127 | d2 = (q>>8) & 0xf; | ||
| 128 | d3 = (q>>12); | ||
| 129 | |||
| 130 | d0 = 6*(d3 + d2 + d1) + (q & 0xf); | ||
| 131 | q = (d0 * 0xcd) >> 11; | ||
| 132 | d0 = d0 - 10*q; | ||
| 133 | *buf++ = d0 + '0'; /* least significant digit */ | ||
| 134 | d1 = q + 9*d3 + 5*d2 + d1; | ||
| 135 | if (d1 != 0) { | ||
| 136 | q = (d1 * 0xcd) >> 11; | ||
| 137 | d1 = d1 - 10*q; | ||
| 138 | *buf++ = d1 + '0'; /* next digit */ | ||
| 139 | |||
| 140 | d2 = q + 2*d2; | ||
| 141 | if ((d2 != 0) || (d3 != 0)) { | ||
| 142 | q = (d2 * 0xd) >> 7; | ||
| 143 | d2 = d2 - 10*q; | ||
| 144 | *buf++ = d2 + '0'; /* next digit */ | ||
| 145 | |||
| 146 | d3 = q + 4*d3; | ||
| 147 | if (d3 != 0) { | ||
| 148 | q = (d3 * 0xcd) >> 11; | ||
| 149 | d3 = d3 - 10*q; | ||
| 150 | *buf++ = d3 + '0'; /* next digit */ | ||
| 151 | if (q != 0) | ||
| 152 | *buf++ = q + '0'; /* most sign. digit */ | ||
| 153 | } | ||
| 154 | } | ||
| 155 | } | ||
| 156 | 125 | ||
| 126 | /* | ||
| 127 | * Possible ways to approx. divide by 10 | ||
| 128 | * (x * 0x1999999a) >> 32 x < 1073741829 (multiply must be 64-bit) | ||
| 129 | * (x * 0xcccd) >> 19 x < 81920 (x < 262149 when 64-bit mul) | ||
| 130 | * (x * 0x6667) >> 18 x < 43699 | ||
| 131 | * (x * 0x3334) >> 17 x < 16389 | ||
| 132 | * (x * 0x199a) >> 16 x < 16389 | ||
| 133 | * (x * 0x0ccd) >> 15 x < 16389 | ||
| 134 | * (x * 0x0667) >> 14 x < 2739 | ||
| 135 | * (x * 0x0334) >> 13 x < 1029 | ||
| 136 | * (x * 0x019a) >> 12 x < 1029 | ||
| 137 | * (x * 0x00cd) >> 11 x < 1029 shorter code than * 0x67 (on i386) | ||
| 138 | * (x * 0x0067) >> 10 x < 179 | ||
| 139 | * (x * 0x0034) >> 9 x < 69 same | ||
| 140 | * (x * 0x001a) >> 8 x < 69 same | ||
| 141 | * (x * 0x000d) >> 7 x < 69 same, shortest code (on i386) | ||
| 142 | * (x * 0x0007) >> 6 x < 19 | ||
| 143 | * See <http://www.cs.uiowa.edu/~jones/bcd/divide.html> | ||
| 144 | */ | ||
| 145 | r = (q * (uint64_t)0x1999999a) >> 32; | ||
| 146 | *buf++ = (q - 10 * r) + '0'; /* 1 */ | ||
| 147 | q = (r * (uint64_t)0x1999999a) >> 32; | ||
| 148 | *buf++ = (r - 10 * q) + '0'; /* 2 */ | ||
| 149 | r = (q * (uint64_t)0x1999999a) >> 32; | ||
| 150 | *buf++ = (q - 10 * r) + '0'; /* 3 */ | ||
| 151 | q = (r * (uint64_t)0x1999999a) >> 32; | ||
| 152 | *buf++ = (r - 10 * q) + '0'; /* 4 */ | ||
| 153 | r = (q * (uint64_t)0x1999999a) >> 32; | ||
| 154 | *buf++ = (q - 10 * r) + '0'; /* 5 */ | ||
| 155 | /* Now value is under 10000, can avoid 64-bit multiply */ | ||
| 156 | q = (r * 0x199a) >> 16; | ||
| 157 | *buf++ = (r - 10 * q) + '0'; /* 6 */ | ||
| 158 | r = (q * 0xcd) >> 11; | ||
| 159 | *buf++ = (q - 10 * r) + '0'; /* 7 */ | ||
| 160 | q = (r * 0xcd) >> 11; | ||
| 161 | *buf++ = (r - 10 * q) + '0'; /* 8 */ | ||
| 162 | *buf++ = q + '0'; /* 9 */ | ||
| 157 | return buf; | 163 | return buf; |
| 158 | } | 164 | } |
| 159 | /* Same with if's removed. Always emits five digits */ | 165 | #endif |
| 166 | |||
| 167 | /* Similar to above but do not pad with zeros. | ||
| 168 | * Code can be easily arranged to print 9 digits too, but our callers | ||
| 169 | * always call put_dec_full9() instead when the number has 9 decimal digits. | ||
| 170 | */ | ||
| 160 | static noinline_for_stack | 171 | static noinline_for_stack |
| 161 | char *put_dec_full(char *buf, unsigned q) | 172 | char *put_dec_trunc8(char *buf, unsigned r) |
| 162 | { | 173 | { |
| 163 | /* BTW, if q is in [0,9999], 8-bit ints will be enough, */ | 174 | unsigned q; |
| 164 | /* but anyway, gcc produces better code with full-sized ints */ | 175 | |
| 165 | unsigned d3, d2, d1, d0; | 176 | /* Copy of previous function's body with added early returns */ |
| 166 | d1 = (q>>4) & 0xf; | 177 | q = (r * (uint64_t)0x1999999a) >> 32; |
| 167 | d2 = (q>>8) & 0xf; | 178 | *buf++ = (r - 10 * q) + '0'; /* 2 */ |
| 168 | d3 = (q>>12); | 179 | if (q == 0) |
| 180 | return buf; | ||
| 181 | r = (q * (uint64_t)0x1999999a) >> 32; | ||
| 182 | *buf++ = (q - 10 * r) + '0'; /* 3 */ | ||
| 183 | if (r == 0) | ||
| 184 | return buf; | ||
| 185 | q = (r * (uint64_t)0x1999999a) >> 32; | ||
| 186 | *buf++ = (r - 10 * q) + '0'; /* 4 */ | ||
| 187 | if (q == 0) | ||
| 188 | return buf; | ||
| 189 | r = (q * (uint64_t)0x1999999a) >> 32; | ||
| 190 | *buf++ = (q - 10 * r) + '0'; /* 5 */ | ||
| 191 | if (r == 0) | ||
| 192 | return buf; | ||
| 193 | q = (r * 0x199a) >> 16; | ||
| 194 | *buf++ = (r - 10 * q) + '0'; /* 6 */ | ||
| 195 | if (q == 0) | ||
| 196 | return buf; | ||
| 197 | r = (q * 0xcd) >> 11; | ||
| 198 | *buf++ = (q - 10 * r) + '0'; /* 7 */ | ||
| 199 | if (r == 0) | ||
| 200 | return buf; | ||
| 201 | q = (r * 0xcd) >> 11; | ||
| 202 | *buf++ = (r - 10 * q) + '0'; /* 8 */ | ||
| 203 | if (q == 0) | ||
| 204 | return buf; | ||
| 205 | *buf++ = q + '0'; /* 9 */ | ||
| 206 | return buf; | ||
| 207 | } | ||
| 169 | 208 | ||
| 170 | /* | 209 | /* There are two algorithms to print larger numbers. |
| 171 | * Possible ways to approx. divide by 10 | 210 | * One is generic: divide by 1000000000 and repeatedly print |
| 172 | * gcc -O2 replaces multiply with shifts and adds | 211 | * groups of (up to) 9 digits. It's conceptually simple, |
| 173 | * (x * 0xcd) >> 11: 11001101 - shorter code than * 0x67 (on i386) | 212 | * but requires a (unsigned long long) / 1000000000 division. |
| 174 | * (x * 0x67) >> 10: 1100111 | 213 | * |
| 175 | * (x * 0x34) >> 9: 110100 - same | 214 | * Second algorithm splits 64-bit unsigned long long into 16-bit chunks, |
| 176 | * (x * 0x1a) >> 8: 11010 - same | 215 | * manipulates them cleverly and generates groups of 4 decimal digits. |
| 177 | * (x * 0x0d) >> 7: 1101 - same, shortest code (on i386) | 216 | * It so happens that it does NOT require long long division. |
| 178 | */ | 217 | * |
| 179 | d0 = 6*(d3 + d2 + d1) + (q & 0xf); | 218 | * If long is > 32 bits, division of 64-bit values is relatively easy, |
| 180 | q = (d0 * 0xcd) >> 11; | 219 | * and we will use the first algorithm. |
| 181 | d0 = d0 - 10*q; | 220 | * If long long is > 64 bits (strange architecture with VERY large long long), |
| 182 | *buf++ = d0 + '0'; | 221 | * second algorithm can't be used, and we again use the first one. |
| 183 | d1 = q + 9*d3 + 5*d2 + d1; | 222 | * |
| 184 | q = (d1 * 0xcd) >> 11; | 223 | * Else (if long is 32 bits and long long is 64 bits) we use second one. |
| 185 | d1 = d1 - 10*q; | 224 | */ |
| 186 | *buf++ = d1 + '0'; | ||
| 187 | |||
| 188 | d2 = q + 2*d2; | ||
| 189 | q = (d2 * 0xd) >> 7; | ||
| 190 | d2 = d2 - 10*q; | ||
| 191 | *buf++ = d2 + '0'; | ||
| 192 | |||
| 193 | d3 = q + 4*d3; | ||
| 194 | q = (d3 * 0xcd) >> 11; /* - shorter code */ | ||
| 195 | /* q = (d3 * 0x67) >> 10; - would also work */ | ||
| 196 | d3 = d3 - 10*q; | ||
| 197 | *buf++ = d3 + '0'; | ||
| 198 | *buf++ = q + '0'; | ||
| 199 | 225 | ||
| 200 | return buf; | 226 | #if BITS_PER_LONG != 32 || BITS_PER_LONG_LONG != 64 |
| 227 | |||
| 228 | /* First algorithm: generic */ | ||
| 229 | |||
| 230 | static | ||
| 231 | char *put_dec(char *buf, unsigned long long n) | ||
| 232 | { | ||
| 233 | if (n >= 100*1000*1000) { | ||
| 234 | while (n >= 1000*1000*1000) | ||
| 235 | buf = put_dec_full9(buf, do_div(n, 1000*1000*1000)); | ||
| 236 | if (n >= 100*1000*1000) | ||
| 237 | return put_dec_full9(buf, n); | ||
| 238 | } | ||
| 239 | return put_dec_trunc8(buf, n); | ||
| 201 | } | 240 | } |
| 202 | /* No inlining helps gcc to use registers better */ | 241 | |
| 242 | #else | ||
| 243 | |||
| 244 | /* Second algorithm: valid only for 64-bit long longs */ | ||
| 245 | |||
| 203 | static noinline_for_stack | 246 | static noinline_for_stack |
| 204 | char *put_dec(char *buf, unsigned long long num) | 247 | char *put_dec_full4(char *buf, unsigned q) |
| 205 | { | 248 | { |
| 206 | while (1) { | 249 | unsigned r; |
| 207 | unsigned rem; | 250 | r = (q * 0xcccd) >> 19; |
| 208 | if (num < 100000) | 251 | *buf++ = (q - 10 * r) + '0'; |
| 209 | return put_dec_trunc(buf, num); | 252 | q = (r * 0x199a) >> 16; |
| 210 | rem = do_div(num, 100000); | 253 | *buf++ = (r - 10 * q) + '0'; |
| 211 | buf = put_dec_full(buf, rem); | 254 | r = (q * 0xcd) >> 11; |
| 212 | } | 255 | *buf++ = (q - 10 * r) + '0'; |
| 256 | *buf++ = r + '0'; | ||
| 257 | return buf; | ||
| 258 | } | ||
| 259 | |||
| 260 | /* Based on code by Douglas W. Jones found at | ||
| 261 | * <http://www.cs.uiowa.edu/~jones/bcd/decimal.html#sixtyfour> | ||
| 262 | * (with permission from the author). | ||
| 263 | * Performs no 64-bit division and hence should be fast on 32-bit machines. | ||
| 264 | */ | ||
| 265 | static | ||
| 266 | char *put_dec(char *buf, unsigned long long n) | ||
| 267 | { | ||
| 268 | uint32_t d3, d2, d1, q, h; | ||
| 269 | |||
| 270 | if (n < 100*1000*1000) | ||
| 271 | return put_dec_trunc8(buf, n); | ||
| 272 | |||
| 273 | d1 = ((uint32_t)n >> 16); /* implicit "& 0xffff" */ | ||
| 274 | h = (n >> 32); | ||
| 275 | d2 = (h ) & 0xffff; | ||
| 276 | d3 = (h >> 16); /* implicit "& 0xffff" */ | ||
| 277 | |||
| 278 | q = 656 * d3 + 7296 * d2 + 5536 * d1 + ((uint32_t)n & 0xffff); | ||
| 279 | |||
| 280 | buf = put_dec_full4(buf, q % 10000); | ||
| 281 | q = q / 10000; | ||
| 282 | |||
| 283 | d1 = q + 7671 * d3 + 9496 * d2 + 6 * d1; | ||
| 284 | buf = put_dec_full4(buf, d1 % 10000); | ||
| 285 | q = d1 / 10000; | ||
| 286 | |||
| 287 | d2 = q + 4749 * d3 + 42 * d2; | ||
| 288 | buf = put_dec_full4(buf, d2 % 10000); | ||
| 289 | q = d2 / 10000; | ||
| 290 | |||
| 291 | d3 = q + 281 * d3; | ||
| 292 | if (!d3) | ||
| 293 | goto done; | ||
| 294 | buf = put_dec_full4(buf, d3 % 10000); | ||
| 295 | q = d3 / 10000; | ||
| 296 | if (!q) | ||
| 297 | goto done; | ||
| 298 | buf = put_dec_full4(buf, q); | ||
| 299 | done: | ||
| 300 | while (buf[-1] == '0') | ||
| 301 | --buf; | ||
| 302 | |||
| 303 | return buf; | ||
| 213 | } | 304 | } |
| 214 | 305 | ||
| 306 | #endif | ||
| 307 | |||
| 215 | /* | 308 | /* |
| 216 | * Convert passed number to decimal string. | 309 | * Convert passed number to decimal string. |
| 217 | * Returns the length of string. On buffer overflow, returns 0. | 310 | * Returns the length of string. On buffer overflow, returns 0. |
| @@ -220,16 +313,22 @@ char *put_dec(char *buf, unsigned long long num) | |||
| 220 | */ | 313 | */ |
| 221 | int num_to_str(char *buf, int size, unsigned long long num) | 314 | int num_to_str(char *buf, int size, unsigned long long num) |
| 222 | { | 315 | { |
| 223 | char tmp[21]; /* Enough for 2^64 in decimal */ | 316 | char tmp[sizeof(num) * 3]; |
| 224 | int idx, len; | 317 | int idx, len; |
| 225 | 318 | ||
| 226 | len = put_dec(tmp, num) - tmp; | 319 | /* put_dec() may work incorrectly for num = 0 (generate "", not "0") */ |
| 320 | if (num <= 9) { | ||
| 321 | tmp[0] = '0' + num; | ||
| 322 | len = 1; | ||
| 323 | } else { | ||
| 324 | len = put_dec(tmp, num) - tmp; | ||
| 325 | } | ||
| 227 | 326 | ||
| 228 | if (len > size) | 327 | if (len > size) |
| 229 | return 0; | 328 | return 0; |
| 230 | for (idx = 0; idx < len; ++idx) | 329 | for (idx = 0; idx < len; ++idx) |
| 231 | buf[idx] = tmp[len - idx - 1]; | 330 | buf[idx] = tmp[len - idx - 1]; |
| 232 | return len; | 331 | return len; |
| 233 | } | 332 | } |
| 234 | 333 | ||
| 235 | #define ZEROPAD 1 /* pad with zero */ | 334 | #define ZEROPAD 1 /* pad with zero */ |
| @@ -284,6 +383,7 @@ char *number(char *buf, char *end, unsigned long long num, | |||
| 284 | char locase; | 383 | char locase; |
| 285 | int need_pfx = ((spec.flags & SPECIAL) && spec.base != 10); | 384 | int need_pfx = ((spec.flags & SPECIAL) && spec.base != 10); |
| 286 | int i; | 385 | int i; |
| 386 | bool is_zero = num == 0LL; | ||
| 287 | 387 | ||
| 288 | /* locase = 0 or 0x20. ORing digits or letters with 'locase' | 388 | /* locase = 0 or 0x20. ORing digits or letters with 'locase' |
| 289 | * produces same digits or (maybe lowercased) letters */ | 389 | * produces same digits or (maybe lowercased) letters */ |
| @@ -305,15 +405,16 @@ char *number(char *buf, char *end, unsigned long long num, | |||
| 305 | } | 405 | } |
| 306 | } | 406 | } |
| 307 | if (need_pfx) { | 407 | if (need_pfx) { |
| 308 | spec.field_width--; | ||
| 309 | if (spec.base == 16) | 408 | if (spec.base == 16) |
| 409 | spec.field_width -= 2; | ||
| 410 | else if (!is_zero) | ||
| 310 | spec.field_width--; | 411 | spec.field_width--; |
| 311 | } | 412 | } |
| 312 | 413 | ||
| 313 | /* generate full string in tmp[], in reverse order */ | 414 | /* generate full string in tmp[], in reverse order */ |
| 314 | i = 0; | 415 | i = 0; |
| 315 | if (num == 0) | 416 | if (num < spec.base) |
| 316 | tmp[i++] = '0'; | 417 | tmp[i++] = digits[num] | locase; |
| 317 | /* Generic code, for any base: | 418 | /* Generic code, for any base: |
| 318 | else do { | 419 | else do { |
| 319 | tmp[i++] = (digits[do_div(num,base)] | locase); | 420 | tmp[i++] = (digits[do_div(num,base)] | locase); |
| @@ -353,9 +454,11 @@ char *number(char *buf, char *end, unsigned long long num, | |||
| 353 | } | 454 | } |
| 354 | /* "0x" / "0" prefix */ | 455 | /* "0x" / "0" prefix */ |
| 355 | if (need_pfx) { | 456 | if (need_pfx) { |
| 356 | if (buf < end) | 457 | if (spec.base == 16 || !is_zero) { |
| 357 | *buf = '0'; | 458 | if (buf < end) |
| 358 | ++buf; | 459 | *buf = '0'; |
| 460 | ++buf; | ||
| 461 | } | ||
| 359 | if (spec.base == 16) { | 462 | if (spec.base == 16) { |
| 360 | if (buf < end) | 463 | if (buf < end) |
| 361 | *buf = ('X' | locase); | 464 | *buf = ('X' | locase); |
| @@ -436,7 +539,7 @@ char *symbol_string(char *buf, char *end, void *ptr, | |||
| 436 | else if (ext != 'f' && ext != 's') | 539 | else if (ext != 'f' && ext != 's') |
| 437 | sprint_symbol(sym, value); | 540 | sprint_symbol(sym, value); |
| 438 | else | 541 | else |
| 439 | kallsyms_lookup(value, NULL, NULL, NULL, sym); | 542 | sprint_symbol_no_offset(sym, value); |
| 440 | 543 | ||
| 441 | return string(buf, end, sym, spec); | 544 | return string(buf, end, sym, spec); |
| 442 | #else | 545 | #else |
| @@ -607,7 +710,7 @@ char *ip4_string(char *p, const u8 *addr, const char *fmt) | |||
| 607 | } | 710 | } |
| 608 | for (i = 0; i < 4; i++) { | 711 | for (i = 0; i < 4; i++) { |
| 609 | char temp[3]; /* hold each IP quad in reverse order */ | 712 | char temp[3]; /* hold each IP quad in reverse order */ |
| 610 | int digits = put_dec_trunc(temp, addr[index]) - temp; | 713 | int digits = put_dec_trunc8(temp, addr[index]) - temp; |
| 611 | if (leading_zeros) { | 714 | if (leading_zeros) { |
| 612 | if (digits < 3) | 715 | if (digits < 3) |
| 613 | *p++ = '0'; | 716 | *p++ = '0'; |
| @@ -866,13 +969,15 @@ static noinline_for_stack | |||
| 866 | char *pointer(const char *fmt, char *buf, char *end, void *ptr, | 969 | char *pointer(const char *fmt, char *buf, char *end, void *ptr, |
| 867 | struct printf_spec spec) | 970 | struct printf_spec spec) |
| 868 | { | 971 | { |
| 972 | int default_width = 2 * sizeof(void *) + (spec.flags & SPECIAL ? 2 : 0); | ||
| 973 | |||
| 869 | if (!ptr && *fmt != 'K') { | 974 | if (!ptr && *fmt != 'K') { |
| 870 | /* | 975 | /* |
| 871 | * Print (null) with the same width as a pointer so it makes | 976 | * Print (null) with the same width as a pointer so it makes |
| 872 | * tabular output look nice. | 977 | * tabular output look nice. |
| 873 | */ | 978 | */ |
| 874 | if (spec.field_width == -1) | 979 | if (spec.field_width == -1) |
| 875 | spec.field_width = 2 * sizeof(void *); | 980 | spec.field_width = default_width; |
| 876 | return string(buf, end, "(null)", spec); | 981 | return string(buf, end, "(null)", spec); |
| 877 | } | 982 | } |
| 878 | 983 | ||
| @@ -927,7 +1032,7 @@ char *pointer(const char *fmt, char *buf, char *end, void *ptr, | |||
| 927 | */ | 1032 | */ |
| 928 | if (in_irq() || in_serving_softirq() || in_nmi()) { | 1033 | if (in_irq() || in_serving_softirq() || in_nmi()) { |
| 929 | if (spec.field_width == -1) | 1034 | if (spec.field_width == -1) |
| 930 | spec.field_width = 2 * sizeof(void *); | 1035 | spec.field_width = default_width; |
| 931 | return string(buf, end, "pK-error", spec); | 1036 | return string(buf, end, "pK-error", spec); |
| 932 | } | 1037 | } |
| 933 | if (!((kptr_restrict == 0) || | 1038 | if (!((kptr_restrict == 0) || |
| @@ -944,7 +1049,7 @@ char *pointer(const char *fmt, char *buf, char *end, void *ptr, | |||
| 944 | } | 1049 | } |
| 945 | spec.flags |= SMALL; | 1050 | spec.flags |= SMALL; |
| 946 | if (spec.field_width == -1) { | 1051 | if (spec.field_width == -1) { |
| 947 | spec.field_width = 2 * sizeof(void *); | 1052 | spec.field_width = default_width; |
| 948 | spec.flags |= ZEROPAD; | 1053 | spec.flags |= ZEROPAD; |
| 949 | } | 1054 | } |
| 950 | spec.base = 16; | 1055 | spec.base = 16; |
