Merge branch 'linus' into core/rcu
Merge reason: Avoid fuzz in init/main.c and update from rc6 to rc8. Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
12
lib/bitmap.c
12
lib/bitmap.c
@@ -179,14 +179,16 @@ void __bitmap_shift_left(unsigned long *dst,
|
||||
}
|
||||
EXPORT_SYMBOL(__bitmap_shift_left);
|
||||
|
||||
void __bitmap_and(unsigned long *dst, const unsigned long *bitmap1,
|
||||
int __bitmap_and(unsigned long *dst, const unsigned long *bitmap1,
|
||||
const unsigned long *bitmap2, int bits)
|
||||
{
|
||||
int k;
|
||||
int nr = BITS_TO_LONGS(bits);
|
||||
unsigned long result = 0;
|
||||
|
||||
for (k = 0; k < nr; k++)
|
||||
dst[k] = bitmap1[k] & bitmap2[k];
|
||||
result |= (dst[k] = bitmap1[k] & bitmap2[k]);
|
||||
return result != 0;
|
||||
}
|
||||
EXPORT_SYMBOL(__bitmap_and);
|
||||
|
||||
@@ -212,14 +214,16 @@ void __bitmap_xor(unsigned long *dst, const unsigned long *bitmap1,
|
||||
}
|
||||
EXPORT_SYMBOL(__bitmap_xor);
|
||||
|
||||
void __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1,
|
||||
int __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1,
|
||||
const unsigned long *bitmap2, int bits)
|
||||
{
|
||||
int k;
|
||||
int nr = BITS_TO_LONGS(bits);
|
||||
unsigned long result = 0;
|
||||
|
||||
for (k = 0; k < nr; k++)
|
||||
dst[k] = bitmap1[k] & ~bitmap2[k];
|
||||
result |= (dst[k] = bitmap1[k] & ~bitmap2[k]);
|
||||
return result != 0;
|
||||
}
|
||||
EXPORT_SYMBOL(__bitmap_andnot);
|
||||
|
||||
|
||||
@@ -156,9 +156,13 @@ static bool driver_filter(struct device *dev)
|
||||
return true;
|
||||
|
||||
/* driver filter on and initialized */
|
||||
if (current_driver && dev->driver == current_driver)
|
||||
if (current_driver && dev && dev->driver == current_driver)
|
||||
return true;
|
||||
|
||||
/* driver filter on, but we can't filter on a NULL device... */
|
||||
if (!dev)
|
||||
return false;
|
||||
|
||||
if (current_driver || !current_driver_name[0])
|
||||
return false;
|
||||
|
||||
@@ -183,17 +187,17 @@ static bool driver_filter(struct device *dev)
|
||||
return ret;
|
||||
}
|
||||
|
||||
#define err_printk(dev, entry, format, arg...) do { \
|
||||
error_count += 1; \
|
||||
if (driver_filter(dev) && \
|
||||
(show_all_errors || show_num_errors > 0)) { \
|
||||
WARN(1, "%s %s: " format, \
|
||||
dev_driver_string(dev), \
|
||||
dev_name(dev) , ## arg); \
|
||||
dump_entry_trace(entry); \
|
||||
} \
|
||||
if (!show_all_errors && show_num_errors > 0) \
|
||||
show_num_errors -= 1; \
|
||||
#define err_printk(dev, entry, format, arg...) do { \
|
||||
error_count += 1; \
|
||||
if (driver_filter(dev) && \
|
||||
(show_all_errors || show_num_errors > 0)) { \
|
||||
WARN(1, "%s %s: " format, \
|
||||
dev ? dev_driver_string(dev) : "NULL", \
|
||||
dev ? dev_name(dev) : "NULL", ## arg); \
|
||||
dump_entry_trace(entry); \
|
||||
} \
|
||||
if (!show_all_errors && show_num_errors > 0) \
|
||||
show_num_errors -= 1; \
|
||||
} while (0);
|
||||
|
||||
/*
|
||||
|
||||
@@ -99,7 +99,8 @@ static inline int elements_fit_in_base(struct flex_array *fa)
|
||||
* capacity in the base structure. Also note that no effort is made
|
||||
* to efficiently pack objects across page boundaries.
|
||||
*/
|
||||
struct flex_array *flex_array_alloc(int element_size, int total, gfp_t flags)
|
||||
struct flex_array *flex_array_alloc(int element_size, unsigned int total,
|
||||
gfp_t flags)
|
||||
{
|
||||
struct flex_array *ret;
|
||||
int max_size = nr_base_part_ptrs() * __elements_per_part(element_size);
|
||||
@@ -115,16 +116,14 @@ struct flex_array *flex_array_alloc(int element_size, int total, gfp_t flags)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int fa_element_to_part_nr(struct flex_array *fa, int element_nr)
|
||||
static int fa_element_to_part_nr(struct flex_array *fa,
|
||||
unsigned int element_nr)
|
||||
{
|
||||
return element_nr / __elements_per_part(fa->element_size);
|
||||
}
|
||||
|
||||
/**
|
||||
* flex_array_free_parts - just free the second-level pages
|
||||
* @src: address of data to copy into the array
|
||||
* @element_nr: index of the position in which to insert
|
||||
* the new element.
|
||||
*
|
||||
* This is to be used in cases where the base 'struct flex_array'
|
||||
* has been statically allocated and should not be free.
|
||||
@@ -146,14 +145,12 @@ void flex_array_free(struct flex_array *fa)
|
||||
kfree(fa);
|
||||
}
|
||||
|
||||
static int fa_index_inside_part(struct flex_array *fa, int element_nr)
|
||||
static unsigned int index_inside_part(struct flex_array *fa,
|
||||
unsigned int element_nr)
|
||||
{
|
||||
return element_nr % __elements_per_part(fa->element_size);
|
||||
}
|
||||
unsigned int part_offset;
|
||||
|
||||
static int index_inside_part(struct flex_array *fa, int element_nr)
|
||||
{
|
||||
int part_offset = fa_index_inside_part(fa, element_nr);
|
||||
part_offset = element_nr % __elements_per_part(fa->element_size);
|
||||
return part_offset * fa->element_size;
|
||||
}
|
||||
|
||||
@@ -188,7 +185,8 @@ __fa_get_part(struct flex_array *fa, int part_nr, gfp_t flags)
|
||||
*
|
||||
* Locking must be provided by the caller.
|
||||
*/
|
||||
int flex_array_put(struct flex_array *fa, int element_nr, void *src, gfp_t flags)
|
||||
int flex_array_put(struct flex_array *fa, unsigned int element_nr, void *src,
|
||||
gfp_t flags)
|
||||
{
|
||||
int part_nr = fa_element_to_part_nr(fa, element_nr);
|
||||
struct flex_array_part *part;
|
||||
@@ -198,10 +196,11 @@ int flex_array_put(struct flex_array *fa, int element_nr, void *src, gfp_t flags
|
||||
return -ENOSPC;
|
||||
if (elements_fit_in_base(fa))
|
||||
part = (struct flex_array_part *)&fa->parts[0];
|
||||
else
|
||||
else {
|
||||
part = __fa_get_part(fa, part_nr, flags);
|
||||
if (!part)
|
||||
return -ENOMEM;
|
||||
if (!part)
|
||||
return -ENOMEM;
|
||||
}
|
||||
dst = &part->elements[index_inside_part(fa, element_nr)];
|
||||
memcpy(dst, src, fa->element_size);
|
||||
return 0;
|
||||
@@ -219,7 +218,8 @@ int flex_array_put(struct flex_array *fa, int element_nr, void *src, gfp_t flags
|
||||
*
|
||||
* Locking must be provided by the caller.
|
||||
*/
|
||||
int flex_array_prealloc(struct flex_array *fa, int start, int end, gfp_t flags)
|
||||
int flex_array_prealloc(struct flex_array *fa, unsigned int start,
|
||||
unsigned int end, gfp_t flags)
|
||||
{
|
||||
int start_part;
|
||||
int end_part;
|
||||
@@ -250,18 +250,19 @@ int flex_array_prealloc(struct flex_array *fa, int start, int end, gfp_t flags)
|
||||
*
|
||||
* Locking must be provided by the caller.
|
||||
*/
|
||||
void *flex_array_get(struct flex_array *fa, int element_nr)
|
||||
void *flex_array_get(struct flex_array *fa, unsigned int element_nr)
|
||||
{
|
||||
int part_nr = fa_element_to_part_nr(fa, element_nr);
|
||||
struct flex_array_part *part;
|
||||
|
||||
if (element_nr >= fa->total_nr_elements)
|
||||
return NULL;
|
||||
if (!fa->parts[part_nr])
|
||||
return NULL;
|
||||
if (elements_fit_in_base(fa))
|
||||
part = (struct flex_array_part *)&fa->parts[0];
|
||||
else
|
||||
else {
|
||||
part = fa->parts[part_nr];
|
||||
if (!part)
|
||||
return NULL;
|
||||
}
|
||||
return &part->elements[index_inside_part(fa, element_nr)];
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user