Merge branch 'perf/urgent' into perf/core
Conflicts: tools/perf/builtin-record.c tools/perf/builtin-top.c tools/perf/perf.h tools/perf/util/top.h Merge reason: resolve these cherry-picking conflicts. Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
@@ -19,6 +19,9 @@ config RATIONAL
|
||||
config GENERIC_FIND_FIRST_BIT
|
||||
bool
|
||||
|
||||
config NO_GENERIC_PCI_IOPORT_MAP
|
||||
bool
|
||||
|
||||
config GENERIC_PCI_IOMAP
|
||||
bool
|
||||
|
||||
|
||||
@@ -44,12 +44,13 @@ const char *_parse_integer_fixup_radix(const char *s, unsigned int *base)
|
||||
*
|
||||
* Don't you dare use this function.
|
||||
*/
|
||||
unsigned int _parse_integer(const char *s, unsigned int base, unsigned long long *res)
|
||||
unsigned int _parse_integer(const char *s, unsigned int base, unsigned long long *p)
|
||||
{
|
||||
unsigned long long res;
|
||||
unsigned int rv;
|
||||
int overflow;
|
||||
|
||||
*res = 0;
|
||||
res = 0;
|
||||
rv = 0;
|
||||
overflow = 0;
|
||||
while (*s) {
|
||||
@@ -64,12 +65,19 @@ unsigned int _parse_integer(const char *s, unsigned int base, unsigned long long
|
||||
|
||||
if (val >= base)
|
||||
break;
|
||||
if (*res > div_u64(ULLONG_MAX - val, base))
|
||||
overflow = 1;
|
||||
*res = *res * base + val;
|
||||
/*
|
||||
* Check for overflow only if we are within range of
|
||||
* it in the max base we support (16)
|
||||
*/
|
||||
if (unlikely(res & (~0ull << 60))) {
|
||||
if (res > div_u64(ULLONG_MAX - val, base))
|
||||
overflow = 1;
|
||||
}
|
||||
res = res * base + val;
|
||||
rv++;
|
||||
s++;
|
||||
}
|
||||
*p = res;
|
||||
if (overflow)
|
||||
rv |= KSTRTOX_OVERFLOW;
|
||||
return rv;
|
||||
|
||||
@@ -34,7 +34,7 @@ void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long maxlen)
|
||||
if (maxlen && len > maxlen)
|
||||
len = maxlen;
|
||||
if (flags & IORESOURCE_IO)
|
||||
return ioport_map(start, len);
|
||||
return __pci_ioport_map(dev, start, len);
|
||||
if (flags & IORESOURCE_MEM) {
|
||||
if (flags & IORESOURCE_CACHEABLE)
|
||||
return ioremap(start, len);
|
||||
|
||||
Reference in New Issue
Block a user