diff options
| author | 2019-02-18 10:12:12 -0500 | |
|---|---|---|
| committer | 2019-02-18 10:12:12 -0500 | |
| commit | 5f09bc8cc4010a3ea17c5881a62fc45192ebe7b0 (patch) | |
| tree | c8e30ba4eaf357699ef97a786bf56661f4591be8 /lib/test_xarray.c | |
| parent | media: vimc: fill in bus_info in media_device_info (diff) | |
| parent | Linux 5.0-rc7 (diff) | |
| download | linux-dev-5f09bc8cc4010a3ea17c5881a62fc45192ebe7b0.tar.xz linux-dev-5f09bc8cc4010a3ea17c5881a62fc45192ebe7b0.zip | |
Merge tag 'v5.0-rc7' into patchwork
Linux 5.0-rc7
* tag 'v5.0-rc7': (1667 commits)
  Linux 5.0-rc7
  Input: elan_i2c - add ACPI ID for touchpad in Lenovo V330-15ISK
  Input: st-keyscan - fix potential zalloc NULL dereference
  Input: apanel - switch to using brightness_set_blocking()
  powerpc/64s: Fix possible corruption on big endian due to pgd/pud_present()
  efi/arm: Revert "Defer persistent reservations until after paging_init()"
  arm64, mm, efi: Account for GICv3 LPI tables in static memblock reserve table
  sunrpc: fix 4 more call sites that were using stack memory with a scatterlist
  include/linux/module.h: copy __init/__exit attrs to init/cleanup_module
  Compiler Attributes: add support for __copy (gcc >= 9)
  lib/crc32.c: mark crc32_le_base/__crc32c_le_base aliases as __pure
  auxdisplay: ht16k33: fix potential user-after-free on module unload
  x86/platform/UV: Use efi_runtime_lock to serialise BIOS calls
  i2c: bcm2835: Clear current buffer pointers and counts after a transfer
  i2c: cadence: Fix the hold bit setting
  drm: Use array_size() when creating lease
  dm thin: fix bug where bio that overwrites thin block ignores FUA
  Revert "exec: load_script: don't blindly truncate shebang string"
  Revert "gfs2: read journal in large chunks to locate the head"
  net: ethernet: freescale: set FEC ethtool regs version
  ...
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
Diffstat (limited to 'lib/test_xarray.c')
| -rw-r--r-- | lib/test_xarray.c | 57 | 
1 files changed, 45 insertions, 12 deletions
| diff --git a/lib/test_xarray.c b/lib/test_xarray.c index 4676c0a1eeca..c596a957f764 100644 --- a/lib/test_xarray.c +++ b/lib/test_xarray.c @@ -199,7 +199,7 @@ static noinline void check_xa_mark_1(struct xarray *xa, unsigned long index)  		XA_BUG_ON(xa, xa_store_index(xa, index + 1, GFP_KERNEL));  		xa_set_mark(xa, index + 1, XA_MARK_0);  		XA_BUG_ON(xa, xa_store_index(xa, index + 2, GFP_KERNEL)); -		xa_set_mark(xa, index + 2, XA_MARK_1); +		xa_set_mark(xa, index + 2, XA_MARK_2);  		XA_BUG_ON(xa, xa_store_index(xa, next, GFP_KERNEL));  		xa_store_order(xa, index, order, xa_mk_index(index),  				GFP_KERNEL); @@ -209,8 +209,8 @@ static noinline void check_xa_mark_1(struct xarray *xa, unsigned long index)  			void *entry;  			XA_BUG_ON(xa, !xa_get_mark(xa, i, XA_MARK_0)); -			XA_BUG_ON(xa, !xa_get_mark(xa, i, XA_MARK_1)); -			XA_BUG_ON(xa, xa_get_mark(xa, i, XA_MARK_2)); +			XA_BUG_ON(xa, xa_get_mark(xa, i, XA_MARK_1)); +			XA_BUG_ON(xa, !xa_get_mark(xa, i, XA_MARK_2));  			/* We should see two elements in the array */  			rcu_read_lock(); @@ -357,7 +357,7 @@ static noinline void check_cmpxchg(struct xarray *xa)  static noinline void check_reserve(struct xarray *xa)  {  	void *entry; -	unsigned long index = 0; +	unsigned long index;  	/* An array with a reserved entry is not empty */  	XA_BUG_ON(xa, !xa_empty(xa)); @@ -382,10 +382,12 @@ static noinline void check_reserve(struct xarray *xa)  	xa_erase_index(xa, 12345678);  	XA_BUG_ON(xa, !xa_empty(xa)); -	/* And so does xa_insert */ +	/* But xa_insert does not */  	xa_reserve(xa, 12345678, GFP_KERNEL); -	XA_BUG_ON(xa, xa_insert(xa, 12345678, xa_mk_value(12345678), 0) != 0); -	xa_erase_index(xa, 12345678); +	XA_BUG_ON(xa, xa_insert(xa, 12345678, xa_mk_value(12345678), 0) != +			-EEXIST); +	XA_BUG_ON(xa, xa_empty(xa)); +	XA_BUG_ON(xa, xa_erase(xa, 12345678) != NULL);  	XA_BUG_ON(xa, !xa_empty(xa));  	/* Can iterate through a reserved entry */ @@ -393,7 +395,7 @@ static noinline void check_reserve(struct xarray *xa)  	xa_reserve(xa, 6, GFP_KERNEL);  	xa_store_index(xa, 7, GFP_KERNEL); -	xa_for_each(xa, entry, index, ULONG_MAX, XA_PRESENT) { +	xa_for_each(xa, index, entry) {  		XA_BUG_ON(xa, index != 5 && index != 7);  	}  	xa_destroy(xa); @@ -812,17 +814,16 @@ static noinline void check_find_1(struct xarray *xa)  static noinline void check_find_2(struct xarray *xa)  {  	void *entry; -	unsigned long i, j, index = 0; +	unsigned long i, j, index; -	xa_for_each(xa, entry, index, ULONG_MAX, XA_PRESENT) { +	xa_for_each(xa, index, entry) {  		XA_BUG_ON(xa, true);  	}  	for (i = 0; i < 1024; i++) {  		xa_store_index(xa, index, GFP_KERNEL);  		j = 0; -		index = 0; -		xa_for_each(xa, entry, index, ULONG_MAX, XA_PRESENT) { +		xa_for_each(xa, index, entry) {  			XA_BUG_ON(xa, xa_mk_index(index) != entry);  			XA_BUG_ON(xa, index != j++);  		} @@ -839,6 +840,7 @@ static noinline void check_find_3(struct xarray *xa)  	for (i = 0; i < 100; i++) {  		for (j = 0; j < 100; j++) { +			rcu_read_lock();  			for (k = 0; k < 100; k++) {  				xas_set(&xas, j);  				xas_for_each_marked(&xas, entry, k, XA_MARK_0) @@ -847,6 +849,7 @@ static noinline void check_find_3(struct xarray *xa)  					XA_BUG_ON(xa,  						xas.xa_node != XAS_RESTART);  			} +			rcu_read_unlock();  		}  		xa_store_index(xa, i, GFP_KERNEL);  		xa_set_mark(xa, i, XA_MARK_0); @@ -1183,6 +1186,35 @@ static noinline void check_store_range(struct xarray *xa)  	}  } +static void check_align_1(struct xarray *xa, char *name) +{ +	int i; +	unsigned int id; +	unsigned long index; +	void *entry; + +	for (i = 0; i < 8; i++) { +		id = 0; +		XA_BUG_ON(xa, xa_alloc(xa, &id, UINT_MAX, name + i, GFP_KERNEL) +				!= 0); +		XA_BUG_ON(xa, id != i); +	} +	xa_for_each(xa, index, entry) +		XA_BUG_ON(xa, xa_is_err(entry)); +	xa_destroy(xa); +} + +static noinline void check_align(struct xarray *xa) +{ +	char name[] = "Motorola 68000"; + +	check_align_1(xa, name); +	check_align_1(xa, name + 1); +	check_align_1(xa, name + 2); +	check_align_1(xa, name + 3); +//	check_align_2(xa, name); +} +  static LIST_HEAD(shadow_nodes);  static void test_update_node(struct xa_node *node) @@ -1332,6 +1364,7 @@ static int xarray_checks(void)  	check_create_range(&array);  	check_store_range(&array);  	check_store_iter(&array); +	check_align(&xa0);  	check_workingset(&array, 0);  	check_workingset(&array, 64); | 
