[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1534651288-30306-1-git-send-email-oceanhehy@gmail.com>
Date: Sun, 19 Aug 2018 00:01:28 -0400
From: Ocean He <oceanhehy@...il.com>
To: dan.j.williams@...el.com, ross.zwisler@...ux.intel.com,
vishal.l.verma@...el.com, dave.jiang@...el.com
Cc: linux-nvdimm@...ts.01.org, linux-kernel@...r.kernel.org,
Ocean He <hehy1@...ovo.com>
Subject: [PATCH] libnvdimm, region_devs: stop NDD_ALIASING bit test if one test pass
From: Ocean He <hehy1@...ovo.com>
There is no need to finish entire loop to execute NDD_ALIASING bit test
against every nvdimm->flags. In practice, all the nd_mapping->nvdimm
have the same flags.
Because the check of alias is "if (alias)" but not
"if (alias == nd_region->ndr_mappings)", there is no function change while
just save a few cycles.
Signed-off-by: Ocean He <hehy1@...ovo.com>
---
A test to check if all the nd_mapping->nvdimm have the same flags, using
Lenovo ThinkSystem SR630 and 4.18-rc6.
# ipmctl show -dimm
DimmID Capacity HealthState ActionRequired LockState FWVersion
0x0021 125.7 GiB Healthy 0 Disabled 01.00.00.4888
0x0121 125.7 GiB Healthy 0 Disabled 01.00.00.4888
0x1021 125.7 GiB Healthy 0 Disabled 01.00.00.4888
0x1121 125.7 GiB Healthy 0 Disabled 01.00.00.4888
# ipmctl create -f -goal -socket 0x0 PersistentMemoryType=AppDirect
# ipmctl create -f -goal -socket 0x1 PersistentMemoryType=AppDirect
# reboot, to make goal configuration take effect.
# ndctl create-namespace -r region0 -s 100m -t pmem -m fsdax
# ndctl create-namespace -r region1 -s 100m -t pmem -m fsdax
# reboot and find all the nd_mapping->nvdimm have the same flags.
drivers/nvdimm/region_devs.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/nvdimm/region_devs.c b/drivers/nvdimm/region_devs.c
index ec3543b..fc3bc1c 100644
--- a/drivers/nvdimm/region_devs.c
+++ b/drivers/nvdimm/region_devs.c
@@ -234,8 +234,10 @@ int nd_region_to_nstype(struct nd_region *nd_region)
struct nd_mapping *nd_mapping = &nd_region->mapping[i];
struct nvdimm *nvdimm = nd_mapping->nvdimm;
- if (test_bit(NDD_ALIASING, &nvdimm->flags))
+ if (test_bit(NDD_ALIASING, &nvdimm->flags)) {
alias++;
+ break;
+ }
}
if (alias)
return ND_DEVICE_NAMESPACE_PMEM;
--
1.8.3.1
Powered by blists - more mailing lists