Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
c44ef859
Commit
c44ef859
authored
Dec 17, 2016
by
Dan Williams
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'for-4.10/libnvdimm' into libnvdimm-for-next
parents
325896ff
d7fe1a67
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
190 additions
and
80 deletions
+190
-80
drivers/dax/dax.c
drivers/dax/dax.c
+94
-0
drivers/dax/pmem.c
drivers/dax/pmem.c
+2
-1
drivers/nvdimm/claim.c
drivers/nvdimm/claim.c
+32
-14
drivers/nvdimm/core.c
drivers/nvdimm/core.c
+0
-29
drivers/nvdimm/dimm.c
drivers/nvdimm/dimm.c
+2
-0
drivers/nvdimm/dimm_devs.c
drivers/nvdimm/dimm_devs.c
+7
-0
drivers/nvdimm/e820.c
drivers/nvdimm/e820.c
+1
-11
drivers/nvdimm/label.c
drivers/nvdimm/label.c
+1
-1
drivers/nvdimm/namespace_devs.c
drivers/nvdimm/namespace_devs.c
+4
-4
drivers/nvdimm/nd.h
drivers/nvdimm/nd.h
+10
-2
drivers/nvdimm/pfn_devs.c
drivers/nvdimm/pfn_devs.c
+1
-1
drivers/nvdimm/pmem.c
drivers/nvdimm/pmem.c
+12
-9
drivers/nvdimm/region_devs.c
drivers/nvdimm/region_devs.c
+1
-1
tools/testing/nvdimm/test/nfit.c
tools/testing/nvdimm/test/nfit.c
+23
-7
No files found.
drivers/dax/dax.c
View file @
c44ef859
...
@@ -75,6 +75,73 @@ struct dax_dev {
...
@@ -75,6 +75,73 @@ struct dax_dev {
struct
resource
res
[
0
];
struct
resource
res
[
0
];
};
};
static
ssize_t
id_show
(
struct
device
*
dev
,
struct
device_attribute
*
attr
,
char
*
buf
)
{
struct
dax_region
*
dax_region
;
ssize_t
rc
=
-
ENXIO
;
device_lock
(
dev
);
dax_region
=
dev_get_drvdata
(
dev
);
if
(
dax_region
)
rc
=
sprintf
(
buf
,
"%d
\n
"
,
dax_region
->
id
);
device_unlock
(
dev
);
return
rc
;
}
static
DEVICE_ATTR_RO
(
id
);
static
ssize_t
region_size_show
(
struct
device
*
dev
,
struct
device_attribute
*
attr
,
char
*
buf
)
{
struct
dax_region
*
dax_region
;
ssize_t
rc
=
-
ENXIO
;
device_lock
(
dev
);
dax_region
=
dev_get_drvdata
(
dev
);
if
(
dax_region
)
rc
=
sprintf
(
buf
,
"%llu
\n
"
,
(
unsigned
long
long
)
resource_size
(
&
dax_region
->
res
));
device_unlock
(
dev
);
return
rc
;
}
static
struct
device_attribute
dev_attr_region_size
=
__ATTR
(
size
,
0444
,
region_size_show
,
NULL
);
static
ssize_t
align_show
(
struct
device
*
dev
,
struct
device_attribute
*
attr
,
char
*
buf
)
{
struct
dax_region
*
dax_region
;
ssize_t
rc
=
-
ENXIO
;
device_lock
(
dev
);
dax_region
=
dev_get_drvdata
(
dev
);
if
(
dax_region
)
rc
=
sprintf
(
buf
,
"%u
\n
"
,
dax_region
->
align
);
device_unlock
(
dev
);
return
rc
;
}
static
DEVICE_ATTR_RO
(
align
);
static
struct
attribute
*
dax_region_attributes
[]
=
{
&
dev_attr_region_size
.
attr
,
&
dev_attr_align
.
attr
,
&
dev_attr_id
.
attr
,
NULL
,
};
static
const
struct
attribute_group
dax_region_attribute_group
=
{
.
name
=
"dax_region"
,
.
attrs
=
dax_region_attributes
,
};
static
const
struct
attribute_group
*
dax_region_attribute_groups
[]
=
{
&
dax_region_attribute_group
,
NULL
,
};
static
struct
inode
*
dax_alloc_inode
(
struct
super_block
*
sb
)
static
struct
inode
*
dax_alloc_inode
(
struct
super_block
*
sb
)
{
{
return
kmem_cache_alloc
(
dax_cache
,
GFP_KERNEL
);
return
kmem_cache_alloc
(
dax_cache
,
GFP_KERNEL
);
...
@@ -200,12 +267,31 @@ void dax_region_put(struct dax_region *dax_region)
...
@@ -200,12 +267,31 @@ void dax_region_put(struct dax_region *dax_region)
}
}
EXPORT_SYMBOL_GPL
(
dax_region_put
);
EXPORT_SYMBOL_GPL
(
dax_region_put
);
static
void
dax_region_unregister
(
void
*
region
)
{
struct
dax_region
*
dax_region
=
region
;
sysfs_remove_groups
(
&
dax_region
->
dev
->
kobj
,
dax_region_attribute_groups
);
dax_region_put
(
dax_region
);
}
struct
dax_region
*
alloc_dax_region
(
struct
device
*
parent
,
int
region_id
,
struct
dax_region
*
alloc_dax_region
(
struct
device
*
parent
,
int
region_id
,
struct
resource
*
res
,
unsigned
int
align
,
void
*
addr
,
struct
resource
*
res
,
unsigned
int
align
,
void
*
addr
,
unsigned
long
pfn_flags
)
unsigned
long
pfn_flags
)
{
{
struct
dax_region
*
dax_region
;
struct
dax_region
*
dax_region
;
/*
* The DAX core assumes that it can store its private data in
* parent->driver_data. This WARN is a reminder / safeguard for
* developers of device-dax drivers.
*/
if
(
dev_get_drvdata
(
parent
))
{
dev_WARN
(
parent
,
"dax core failed to setup private data
\n
"
);
return
NULL
;
}
if
(
!
IS_ALIGNED
(
res
->
start
,
align
)
if
(
!
IS_ALIGNED
(
res
->
start
,
align
)
||
!
IS_ALIGNED
(
resource_size
(
res
),
align
))
||
!
IS_ALIGNED
(
resource_size
(
res
),
align
))
return
NULL
;
return
NULL
;
...
@@ -214,6 +300,7 @@ struct dax_region *alloc_dax_region(struct device *parent, int region_id,
...
@@ -214,6 +300,7 @@ struct dax_region *alloc_dax_region(struct device *parent, int region_id,
if
(
!
dax_region
)
if
(
!
dax_region
)
return
NULL
;
return
NULL
;
dev_set_drvdata
(
parent
,
dax_region
);
memcpy
(
&
dax_region
->
res
,
res
,
sizeof
(
*
res
));
memcpy
(
&
dax_region
->
res
,
res
,
sizeof
(
*
res
));
dax_region
->
pfn_flags
=
pfn_flags
;
dax_region
->
pfn_flags
=
pfn_flags
;
kref_init
(
&
dax_region
->
kref
);
kref_init
(
&
dax_region
->
kref
);
...
@@ -222,7 +309,14 @@ struct dax_region *alloc_dax_region(struct device *parent, int region_id,
...
@@ -222,7 +309,14 @@ struct dax_region *alloc_dax_region(struct device *parent, int region_id,
dax_region
->
align
=
align
;
dax_region
->
align
=
align
;
dax_region
->
dev
=
parent
;
dax_region
->
dev
=
parent
;
dax_region
->
base
=
addr
;
dax_region
->
base
=
addr
;
if
(
sysfs_create_groups
(
&
parent
->
kobj
,
dax_region_attribute_groups
))
{
kfree
(
dax_region
);
return
NULL
;;
}
kref_get
(
&
dax_region
->
kref
);
if
(
devm_add_action_or_reset
(
parent
,
dax_region_unregister
,
dax_region
))
return
NULL
;
return
dax_region
;
return
dax_region
;
}
}
EXPORT_SYMBOL_GPL
(
alloc_dax_region
);
EXPORT_SYMBOL_GPL
(
alloc_dax_region
);
...
...
drivers/dax/pmem.c
View file @
c44ef859
...
@@ -89,7 +89,8 @@ static int dax_pmem_probe(struct device *dev)
...
@@ -89,7 +89,8 @@ static int dax_pmem_probe(struct device *dev)
pfn_sb
=
nd_pfn
->
pfn_sb
;
pfn_sb
=
nd_pfn
->
pfn_sb
;
if
(
!
devm_request_mem_region
(
dev
,
nsio
->
res
.
start
,
if
(
!
devm_request_mem_region
(
dev
,
nsio
->
res
.
start
,
resource_size
(
&
nsio
->
res
),
dev_name
(
dev
)))
{
resource_size
(
&
nsio
->
res
),
dev_name
(
&
ndns
->
dev
)))
{
dev_warn
(
dev
,
"could not reserve region %pR
\n
"
,
&
nsio
->
res
);
dev_warn
(
dev
,
"could not reserve region %pR
\n
"
,
&
nsio
->
res
);
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
...
drivers/nvdimm/claim.c
View file @
c44ef859
...
@@ -22,9 +22,8 @@ void __nd_detach_ndns(struct device *dev, struct nd_namespace_common **_ndns)
...
@@ -22,9 +22,8 @@ void __nd_detach_ndns(struct device *dev, struct nd_namespace_common **_ndns)
{
{
struct
nd_namespace_common
*
ndns
=
*
_ndns
;
struct
nd_namespace_common
*
ndns
=
*
_ndns
;
dev_WARN_ONCE
(
dev
,
!
mutex_is_locked
(
&
ndns
->
dev
.
mutex
)
lockdep_assert_held
(
&
ndns
->
dev
.
mutex
);
||
ndns
->
claim
!=
dev
,
dev_WARN_ONCE
(
dev
,
ndns
->
claim
!=
dev
,
"%s: invalid claim
\n
"
,
__func__
);
"%s: invalid claim
\n
"
,
__func__
);
ndns
->
claim
=
NULL
;
ndns
->
claim
=
NULL
;
*
_ndns
=
NULL
;
*
_ndns
=
NULL
;
put_device
(
&
ndns
->
dev
);
put_device
(
&
ndns
->
dev
);
...
@@ -49,9 +48,8 @@ bool __nd_attach_ndns(struct device *dev, struct nd_namespace_common *attach,
...
@@ -49,9 +48,8 @@ bool __nd_attach_ndns(struct device *dev, struct nd_namespace_common *attach,
{
{
if
(
attach
->
claim
)
if
(
attach
->
claim
)
return
false
;
return
false
;
dev_WARN_ONCE
(
dev
,
!
mutex_is_locked
(
&
attach
->
dev
.
mutex
)
lockdep_assert_held
(
&
attach
->
dev
.
mutex
);
||
*
_ndns
,
dev_WARN_ONCE
(
dev
,
*
_ndns
,
"%s: invalid claim
\n
"
,
__func__
);
"%s: invalid claim
\n
"
,
__func__
);
attach
->
claim
=
dev
;
attach
->
claim
=
dev
;
*
_ndns
=
attach
;
*
_ndns
=
attach
;
get_device
(
&
attach
->
dev
);
get_device
(
&
attach
->
dev
);
...
@@ -226,6 +224,12 @@ static int nsio_rw_bytes(struct nd_namespace_common *ndns,
...
@@ -226,6 +224,12 @@ static int nsio_rw_bytes(struct nd_namespace_common *ndns,
resource_size_t
offset
,
void
*
buf
,
size_t
size
,
int
rw
)
resource_size_t
offset
,
void
*
buf
,
size_t
size
,
int
rw
)
{
{
struct
nd_namespace_io
*
nsio
=
to_nd_namespace_io
(
&
ndns
->
dev
);
struct
nd_namespace_io
*
nsio
=
to_nd_namespace_io
(
&
ndns
->
dev
);
unsigned
int
sz_align
=
ALIGN
(
size
+
(
offset
&
(
512
-
1
)),
512
);
sector_t
sector
=
offset
>>
9
;
int
rc
=
0
;
if
(
unlikely
(
!
size
))
return
0
;
if
(
unlikely
(
offset
+
size
>
nsio
->
size
))
{
if
(
unlikely
(
offset
+
size
>
nsio
->
size
))
{
dev_WARN_ONCE
(
&
ndns
->
dev
,
1
,
"request out of range
\n
"
);
dev_WARN_ONCE
(
&
ndns
->
dev
,
1
,
"request out of range
\n
"
);
...
@@ -233,17 +237,31 @@ static int nsio_rw_bytes(struct nd_namespace_common *ndns,
...
@@ -233,17 +237,31 @@ static int nsio_rw_bytes(struct nd_namespace_common *ndns,
}
}
if
(
rw
==
READ
)
{
if
(
rw
==
READ
)
{
unsigned
int
sz_align
=
ALIGN
(
size
+
(
offset
&
(
512
-
1
)),
512
);
if
(
unlikely
(
is_bad_pmem
(
&
nsio
->
bb
,
sector
,
sz_align
)))
if
(
unlikely
(
is_bad_pmem
(
&
nsio
->
bb
,
offset
/
512
,
sz_align
)))
return
-
EIO
;
return
-
EIO
;
return
memcpy_from_pmem
(
buf
,
nsio
->
addr
+
offset
,
size
);
return
memcpy_from_pmem
(
buf
,
nsio
->
addr
+
offset
,
size
);
}
else
{
memcpy_to_pmem
(
nsio
->
addr
+
offset
,
buf
,
size
);
nvdimm_flush
(
to_nd_region
(
ndns
->
dev
.
parent
));
}
}
return
0
;
if
(
unlikely
(
is_bad_pmem
(
&
nsio
->
bb
,
sector
,
sz_align
)))
{
if
(
IS_ALIGNED
(
offset
,
512
)
&&
IS_ALIGNED
(
size
,
512
))
{
long
cleared
;
cleared
=
nvdimm_clear_poison
(
&
ndns
->
dev
,
offset
,
size
);
if
(
cleared
<
size
)
rc
=
-
EIO
;
if
(
cleared
>
0
&&
cleared
/
512
)
{
cleared
/=
512
;
badblocks_clear
(
&
nsio
->
bb
,
sector
,
cleared
);
}
invalidate_pmem
(
nsio
->
addr
+
offset
,
size
);
}
else
rc
=
-
EIO
;
}
memcpy_to_pmem
(
nsio
->
addr
+
offset
,
buf
,
size
);
nvdimm_flush
(
to_nd_region
(
ndns
->
dev
.
parent
));
return
rc
;
}
}
int
devm_nsio_enable
(
struct
device
*
dev
,
struct
nd_namespace_io
*
nsio
)
int
devm_nsio_enable
(
struct
device
*
dev
,
struct
nd_namespace_io
*
nsio
)
...
@@ -253,7 +271,7 @@ int devm_nsio_enable(struct device *dev, struct nd_namespace_io *nsio)
...
@@ -253,7 +271,7 @@ int devm_nsio_enable(struct device *dev, struct nd_namespace_io *nsio)
nsio
->
size
=
resource_size
(
res
);
nsio
->
size
=
resource_size
(
res
);
if
(
!
devm_request_mem_region
(
dev
,
res
->
start
,
resource_size
(
res
),
if
(
!
devm_request_mem_region
(
dev
,
res
->
start
,
resource_size
(
res
),
dev_name
(
dev
)))
{
dev_name
(
&
ndns
->
dev
)))
{
dev_warn
(
dev
,
"could not reserve region %pR
\n
"
,
res
);
dev_warn
(
dev
,
"could not reserve region %pR
\n
"
,
res
);
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
...
drivers/nvdimm/core.c
View file @
c44ef859
...
@@ -317,35 +317,6 @@ ssize_t nd_sector_size_store(struct device *dev, const char *buf,
...
@@ -317,35 +317,6 @@ ssize_t nd_sector_size_store(struct device *dev, const char *buf,
}
}
}
}
void
__nd_iostat_start
(
struct
bio
*
bio
,
unsigned
long
*
start
)
{
struct
gendisk
*
disk
=
bio
->
bi_bdev
->
bd_disk
;
const
int
rw
=
bio_data_dir
(
bio
);
int
cpu
=
part_stat_lock
();
*
start
=
jiffies
;
part_round_stats
(
cpu
,
&
disk
->
part0
);
part_stat_inc
(
cpu
,
&
disk
->
part0
,
ios
[
rw
]);
part_stat_add
(
cpu
,
&
disk
->
part0
,
sectors
[
rw
],
bio_sectors
(
bio
));
part_inc_in_flight
(
&
disk
->
part0
,
rw
);
part_stat_unlock
();
}
EXPORT_SYMBOL
(
__nd_iostat_start
);
void
nd_iostat_end
(
struct
bio
*
bio
,
unsigned
long
start
)
{
struct
gendisk
*
disk
=
bio
->
bi_bdev
->
bd_disk
;
unsigned
long
duration
=
jiffies
-
start
;
const
int
rw
=
bio_data_dir
(
bio
);
int
cpu
=
part_stat_lock
();
part_stat_add
(
cpu
,
&
disk
->
part0
,
ticks
[
rw
],
duration
);
part_round_stats
(
cpu
,
&
disk
->
part0
);
part_dec_in_flight
(
&
disk
->
part0
,
rw
);
part_stat_unlock
();
}
EXPORT_SYMBOL
(
nd_iostat_end
);
static
ssize_t
commands_show
(
struct
device
*
dev
,
static
ssize_t
commands_show
(
struct
device
*
dev
,
struct
device_attribute
*
attr
,
char
*
buf
)
struct
device_attribute
*
attr
,
char
*
buf
)
{
{
...
...
drivers/nvdimm/dimm.c
View file @
c44ef859
...
@@ -64,6 +64,8 @@ static int nvdimm_probe(struct device *dev)
...
@@ -64,6 +64,8 @@ static int nvdimm_probe(struct device *dev)
nd_label_copy
(
ndd
,
to_next_namespace_index
(
ndd
),
nd_label_copy
(
ndd
,
to_next_namespace_index
(
ndd
),
to_current_namespace_index
(
ndd
));
to_current_namespace_index
(
ndd
));
rc
=
nd_label_reserve_dpa
(
ndd
);
rc
=
nd_label_reserve_dpa
(
ndd
);
if
(
ndd
->
ns_current
>=
0
)
nvdimm_set_aliasing
(
dev
);
nvdimm_bus_unlock
(
dev
);
nvdimm_bus_unlock
(
dev
);
if
(
rc
)
if
(
rc
)
...
...
drivers/nvdimm/dimm_devs.c
View file @
c44ef859
...
@@ -184,6 +184,13 @@ int nvdimm_set_config_data(struct nvdimm_drvdata *ndd, size_t offset,
...
@@ -184,6 +184,13 @@ int nvdimm_set_config_data(struct nvdimm_drvdata *ndd, size_t offset,
return
rc
;
return
rc
;
}
}
void
nvdimm_set_aliasing
(
struct
device
*
dev
)
{
struct
nvdimm
*
nvdimm
=
to_nvdimm
(
dev
);
nvdimm
->
flags
|=
NDD_ALIASING
;
}
static
void
nvdimm_release
(
struct
device
*
dev
)
static
void
nvdimm_release
(
struct
device
*
dev
)
{
{
struct
nvdimm
*
nvdimm
=
to_nvdimm
(
dev
);
struct
nvdimm
*
nvdimm
=
to_nvdimm
(
dev
);
...
...
drivers/nvdimm/e820.c
View file @
c44ef859
...
@@ -84,18 +84,8 @@ static struct platform_driver e820_pmem_driver = {
...
@@ -84,18 +84,8 @@ static struct platform_driver e820_pmem_driver = {
},
},
};
};
static
__init
int
e820_pmem_init
(
void
)
module_platform_driver
(
e820_pmem_driver
);
{
return
platform_driver_register
(
&
e820_pmem_driver
);
}
static
__exit
void
e820_pmem_exit
(
void
)
{
platform_driver_unregister
(
&
e820_pmem_driver
);
}
MODULE_ALIAS
(
"platform:e820_pmem*"
);
MODULE_ALIAS
(
"platform:e820_pmem*"
);
MODULE_LICENSE
(
"GPL v2"
);
MODULE_LICENSE
(
"GPL v2"
);
MODULE_AUTHOR
(
"Intel Corporation"
);
MODULE_AUTHOR
(
"Intel Corporation"
);
module_init
(
e820_pmem_init
);
module_exit
(
e820_pmem_exit
);
drivers/nvdimm/label.c
View file @
c44ef859
...
@@ -938,7 +938,7 @@ int nd_pmem_namespace_label_update(struct nd_region *nd_region,
...
@@ -938,7 +938,7 @@ int nd_pmem_namespace_label_update(struct nd_region *nd_region,
}
}
for_each_dpa_resource
(
ndd
,
res
)
for_each_dpa_resource
(
ndd
,
res
)
if
(
strncmp
(
res
->
name
,
"pmem"
,
3
)
==
0
)
if
(
strncmp
(
res
->
name
,
"pmem"
,
4
)
==
0
)
count
++
;
count
++
;
WARN_ON_ONCE
(
!
count
);
WARN_ON_ONCE
(
!
count
);
...
...
drivers/nvdimm/namespace_devs.c
View file @
c44ef859
...
@@ -1132,7 +1132,7 @@ static ssize_t size_show(struct device *dev,
...
@@ -1132,7 +1132,7 @@ static ssize_t size_show(struct device *dev,
return
sprintf
(
buf
,
"%llu
\n
"
,
(
unsigned
long
long
)
return
sprintf
(
buf
,
"%llu
\n
"
,
(
unsigned
long
long
)
nvdimm_namespace_capacity
(
to_ndns
(
dev
)));
nvdimm_namespace_capacity
(
to_ndns
(
dev
)));
}
}
static
DEVICE_ATTR
(
size
,
S_IRUGO
,
size_show
,
size_store
);
static
DEVICE_ATTR
(
size
,
0444
,
size_show
,
size_store
);
static
u8
*
namespace_to_uuid
(
struct
device
*
dev
)
static
u8
*
namespace_to_uuid
(
struct
device
*
dev
)
{
{
...
@@ -1456,7 +1456,7 @@ static umode_t namespace_visible(struct kobject *kobj,
...
@@ -1456,7 +1456,7 @@ static umode_t namespace_visible(struct kobject *kobj,
if
(
is_namespace_pmem
(
dev
)
||
is_namespace_blk
(
dev
))
{
if
(
is_namespace_pmem
(
dev
)
||
is_namespace_blk
(
dev
))
{
if
(
a
==
&
dev_attr_size
.
attr
)
if
(
a
==
&
dev_attr_size
.
attr
)
return
S_IWUSR
|
S_IRUGO
;
return
0644
;
if
(
is_namespace_pmem
(
dev
)
&&
a
==
&
dev_attr_sector_size
.
attr
)
if
(
is_namespace_pmem
(
dev
)
&&
a
==
&
dev_attr_sector_size
.
attr
)
return
0
;
return
0
;
...
@@ -1653,7 +1653,7 @@ static int select_pmem_id(struct nd_region *nd_region, u8 *pmem_id)
...
@@ -1653,7 +1653,7 @@ static int select_pmem_id(struct nd_region *nd_region, u8 *pmem_id)
u64
hw_start
,
hw_end
,
pmem_start
,
pmem_end
;
u64
hw_start
,
hw_end
,
pmem_start
,
pmem_end
;
struct
nd_label_ent
*
label_ent
;
struct
nd_label_ent
*
label_ent
;
WARN_ON
(
!
mutex_is_locked
(
&
nd_mapping
->
lock
)
);
lockdep_assert_held
(
&
nd_mapping
->
lock
);
list_for_each_entry
(
label_ent
,
&
nd_mapping
->
labels
,
list
)
{
list_for_each_entry
(
label_ent
,
&
nd_mapping
->
labels
,
list
)
{
nd_label
=
label_ent
->
label
;
nd_label
=
label_ent
->
label
;
if
(
!
nd_label
)
if
(
!
nd_label
)
...
@@ -1997,7 +1997,7 @@ struct device *create_namespace_blk(struct nd_region *nd_region,
...
@@ -1997,7 +1997,7 @@ struct device *create_namespace_blk(struct nd_region *nd_region,
struct
nd_mapping
*
nd_mapping
=
&
nd_region
->
mapping
[
0
];
struct
nd_mapping
*
nd_mapping
=
&
nd_region
->
mapping
[
0
];
struct
nvdimm_drvdata
*
ndd
=
to_ndd
(
nd_mapping
);
struct
nvdimm_drvdata
*
ndd
=
to_ndd
(
nd_mapping
);
struct
nd_namespace_blk
*
nsblk
;
struct
nd_namespace_blk
*
nsblk
;
char
*
name
[
NSLABEL_NAME_LEN
];
char
name
[
NSLABEL_NAME_LEN
];
struct
device
*
dev
=
NULL
;
struct
device
*
dev
=
NULL
;
struct
resource
*
res
;
struct
resource
*
res
;
...
...
drivers/nvdimm/nd.h
View file @
c44ef859
...
@@ -238,6 +238,7 @@ int nvdimm_set_config_data(struct nvdimm_drvdata *ndd, size_t offset,
...
@@ -238,6 +238,7 @@ int nvdimm_set_config_data(struct nvdimm_drvdata *ndd, size_t offset,
void
*
buf
,
size_t
len
);
void
*
buf
,
size_t
len
);
long
nvdimm_clear_poison
(
struct
device
*
dev
,
phys_addr_t
phys
,
long
nvdimm_clear_poison
(
struct
device
*
dev
,
phys_addr_t
phys
,
unsigned
int
len
);
unsigned
int
len
);
void
nvdimm_set_aliasing
(
struct
device
*
dev
);
struct
nd_btt
*
to_nd_btt
(
struct
device
*
dev
);
struct
nd_btt
*
to_nd_btt
(
struct
device
*
dev
);
struct
nd_gen_sb
{
struct
nd_gen_sb
{
...
@@ -377,10 +378,17 @@ static inline bool nd_iostat_start(struct bio *bio, unsigned long *start)
...
@@ -377,10 +378,17 @@ static inline bool nd_iostat_start(struct bio *bio, unsigned long *start)
if
(
!
blk_queue_io_stat
(
disk
->
queue
))
if
(
!
blk_queue_io_stat
(
disk
->
queue
))
return
false
;
return
false
;
__nd_iostat_start
(
bio
,
start
);
*
start
=
jiffies
;
generic_start_io_acct
(
bio_data_dir
(
bio
),
bio_sectors
(
bio
),
&
disk
->
part0
);
return
true
;
return
true
;
}
}
void
nd_iostat_end
(
struct
bio
*
bio
,
unsigned
long
start
);
static
inline
void
nd_iostat_end
(
struct
bio
*
bio
,
unsigned
long
start
)
{
struct
gendisk
*
disk
=
bio
->
bi_bdev
->
bd_disk
;
generic_end_io_acct
(
bio_data_dir
(
bio
),
&
disk
->
part0
,
start
);
}
static
inline
bool
is_bad_pmem
(
struct
badblocks
*
bb
,
sector_t
sector
,
static
inline
bool
is_bad_pmem
(
struct
badblocks
*
bb
,
sector_t
sector
,
unsigned
int
len
)
unsigned
int
len
)
{
{
...
...
drivers/nvdimm/pfn_devs.c
View file @
c44ef859
...
@@ -108,7 +108,7 @@ static ssize_t align_show(struct device *dev,
...
@@ -108,7 +108,7 @@ static ssize_t align_show(struct device *dev,
{
{
struct
nd_pfn
*
nd_pfn
=
to_nd_pfn_safe
(
dev
);
struct
nd_pfn
*
nd_pfn
=
to_nd_pfn_safe
(
dev
);
return
sprintf
(
buf
,
"%l
x
\n
"
,
nd_pfn
->
align
);
return
sprintf
(
buf
,
"%l
d
\n
"
,
nd_pfn
->
align
);
}
}
static
ssize_t
__align_store
(
struct
nd_pfn
*
nd_pfn
,
const
char
*
buf
)
static
ssize_t
__align_store
(
struct
nd_pfn
*
nd_pfn
,
const
char
*
buf
)
...
...
drivers/nvdimm/pmem.c
View file @
c44ef859
...
@@ -53,21 +53,24 @@ static int pmem_clear_poison(struct pmem_device *pmem, phys_addr_t offset,
...
@@ -53,21 +53,24 @@ static int pmem_clear_poison(struct pmem_device *pmem, phys_addr_t offset,
struct
device
*
dev
=
to_dev
(
pmem
);
struct
device
*
dev
=
to_dev
(
pmem
);
sector_t
sector
;
sector_t
sector
;
long
cleared
;
long
cleared
;
int
rc
=
0
;
sector
=
(
offset
-
pmem
->
data_offset
)
/
512
;
sector
=
(
offset
-
pmem
->
data_offset
)
/
512
;
cleared
=
nvdimm_clear_poison
(
dev
,
pmem
->
phys_addr
+
offset
,
len
);
cleared
=
nvdimm_clear_poison
(
dev
,
pmem
->
phys_addr
+
offset
,
len
);
if
(
cleared
<
len
)
rc
=
-
EIO
;
if
(
cleared
>
0
&&
cleared
/
512
)
{
if
(
cleared
>
0
&&
cleared
/
512
)
{
dev_dbg
(
dev
,
"%s: %#llx clear %ld sector%s
\n
"
,
cleared
/=
512
;
__func__
,
(
unsigned
long
long
)
sector
,
dev_dbg
(
dev
,
"%s: %#llx clear %ld sector%s
\n
"
,
__func__
,
cleared
/
512
,
cleared
/
512
>
1
?
"s"
:
""
);
(
unsigned
long
long
)
sector
,
cleared
,
badblocks_clear
(
&
pmem
->
bb
,
sector
,
cleared
/
512
);
cleared
>
1
?
"s"
:
""
);
}
else
{
badblocks_clear
(
&
pmem
->
bb
,
sector
,
cleared
);
return
-
EIO
;
}
}
invalidate_pmem
(
pmem
->
virt_addr
+
offset
,
len
);
invalidate_pmem
(
pmem
->
virt_addr
+
offset
,
len
);
return
0
;
return
rc
;
}
}
static
void
write_pmem
(
void
*
pmem_addr
,
struct
page
*
page
,
static
void
write_pmem
(
void
*
pmem_addr
,
struct
page
*
page
,
...
@@ -270,7 +273,7 @@ static int pmem_attach_disk(struct device *dev,
...
@@ -270,7 +273,7 @@ static int pmem_attach_disk(struct device *dev,
dev_warn
(
dev
,
"unable to guarantee persistence of writes
\n
"
);
dev_warn
(
dev
,
"unable to guarantee persistence of writes
\n
"
);
if
(
!
devm_request_mem_region
(
dev
,
res
->
start
,
resource_size
(
res
),
if
(
!
devm_request_mem_region
(
dev
,
res
->
start
,
resource_size
(
res
),
dev_name
(
dev
)))
{
dev_name
(
&
ndns
->
dev
)))
{
dev_warn
(
dev
,
"could not reserve region %pR
\n
"
,
res
);
dev_warn
(
dev
,
"could not reserve region %pR
\n
"
,
res
);
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
...
drivers/nvdimm/region_devs.c
View file @
c44ef859
...
@@ -509,7 +509,7 @@ void nd_mapping_free_labels(struct nd_mapping *nd_mapping)
...
@@ -509,7 +509,7 @@ void nd_mapping_free_labels(struct nd_mapping *nd_mapping)
{
{
struct
nd_label_ent
*
label_ent
,
*
e
;
struct
nd_label_ent
*
label_ent
,
*
e
;
WARN_ON
(
!
mutex_is_locked
(
&
nd_mapping
->
lock
)
);
lockdep_assert_held
(
&
nd_mapping
->
lock
);
list_for_each_entry_safe
(
label_ent
,
e
,
&
nd_mapping
->
labels
,
list
)
{
list_for_each_entry_safe
(
label_ent
,
e
,
&
nd_mapping
->
labels
,
list
)
{
list_del
(
&
label_ent
->
list
);
list_del
(
&
label_ent
->
list
);
kfree
(
label_ent
);
kfree
(
label_ent
);
...
...
tools/testing/nvdimm/test/nfit.c
View file @
c44ef859
...
@@ -125,12 +125,13 @@ struct nfit_test_dcr {
...
@@ -125,12 +125,13 @@ struct nfit_test_dcr {
(((node & 0xfff) << 16) | ((socket & 0xf) << 12) \
(((node & 0xfff) << 16) | ((socket & 0xf) << 12) \
| ((imc & 0xf) << 8) | ((chan & 0xf) << 4) | (dimm & 0xf))
| ((imc & 0xf) << 8) | ((chan & 0xf) << 4) | (dimm & 0xf))
static
u32
handle
[
NUM_DCR
]
=
{
static
u32
handle
[]
=
{
[
0
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
0
,
0
,
0
),
[
0
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
0
,
0
,
0
),
[
1
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
0
,
0
,
1
),
[
1
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
0
,
0
,
1
),
[
2
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
1
,
0
,
0
),
[
2
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
1
,
0
,
0
),
[
3
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
1
,
0
,
1
),
[
3
]
=
NFIT_DIMM_HANDLE
(
0
,
0
,
1
,
0
,
1
),
[
4
]
=
NFIT_DIMM_HANDLE
(
0
,
1
,
0
,
0
,
0
),
[
4
]
=
NFIT_DIMM_HANDLE
(
0
,
1
,
0
,
0
,
0
),
[
5
]
=
NFIT_DIMM_HANDLE
(
1
,
0
,
0
,
0
,
0
),
};
};
static
unsigned
long
dimm_fail_cmd_flags
[
NUM_DCR
];
static
unsigned
long
dimm_fail_cmd_flags
[
NUM_DCR
];
...
@@ -142,6 +143,7 @@ struct nfit_test {
...
@@ -142,6 +143,7 @@ struct nfit_test {
void
*
nfit_buf
;
void
*
nfit_buf
;
dma_addr_t
nfit_dma
;
dma_addr_t
nfit_dma
;
size_t
nfit_size
;
size_t
nfit_size
;
int
dcr_idx
;
int
num_dcr
;
int
num_dcr
;
int
num_pm
;
int
num_pm
;
void
**
dimm
;
void
**
dimm
;
...
@@ -426,11 +428,11 @@ static int nfit_test_ctl(struct nvdimm_bus_descriptor *nd_desc,
...
@@ -426,11 +428,11 @@ static int nfit_test_ctl(struct nvdimm_bus_descriptor *nd_desc,
break
;
break
;
case
ND_CMD_GET_CONFIG_DATA
:
case
ND_CMD_GET_CONFIG_DATA
:
rc
=
nfit_test_cmd_get_config_data
(
buf
,
buf_len
,
rc
=
nfit_test_cmd_get_config_data
(
buf
,
buf_len
,
t
->
label
[
i
]);
t
->
label
[
i
-
t
->
dcr_idx
]);
break
;
break
;
case
ND_CMD_SET_CONFIG_DATA
:
case
ND_CMD_SET_CONFIG_DATA
:
rc
=
nfit_test_cmd_set_config_data
(
buf
,
buf_len
,
rc
=
nfit_test_cmd_set_config_data
(
buf
,
buf_len
,
t
->
label
[
i
]);
t
->
label
[
i
-
t
->
dcr_idx
]);
break
;
break
;
case
ND_CMD_SMART
:
case
ND_CMD_SMART
:
rc
=
nfit_test_cmd_smart
(
buf
,
buf_len
);
rc
=
nfit_test_cmd_smart
(
buf
,
buf_len
);
...
@@ -682,7 +684,7 @@ static int nfit_test0_alloc(struct nfit_test *t)
...
@@ -682,7 +684,7 @@ static int nfit_test0_alloc(struct nfit_test *t)
if
(
!
t
->
spa_set
[
2
])
if
(
!
t
->
spa_set
[
2
])
return
-
ENOMEM
;
return
-
ENOMEM
;
for
(
i
=
0
;
i
<
NUM_DCR
;
i
++
)
{
for
(
i
=
0
;
i
<
t
->
num_dcr
;
i
++
)
{
t
->
dimm
[
i
]
=
test_alloc
(
t
,
DIMM_SIZE
,
&
t
->
dimm_dma
[
i
]);
t
->
dimm
[
i
]
=
test_alloc
(
t
,
DIMM_SIZE
,
&
t
->
dimm_dma
[
i
]);
if
(
!
t
->
dimm
[
i
])
if
(
!
t
->
dimm
[
i
])
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -699,7 +701,7 @@ static int nfit_test0_alloc(struct nfit_test *t)
...
@@ -699,7 +701,7 @@ static int nfit_test0_alloc(struct nfit_test *t)
return
-
ENOMEM
;
return
-
ENOMEM
;
}
}
for
(
i
=
0
;
i
<
NUM_DCR
;
i
++
)
{
for
(
i
=
0
;
i
<
t
->
num_dcr
;
i
++
)
{
t
->
dcr
[
i
]
=
test_alloc
(
t
,
LABEL_SIZE
,
&
t
->
dcr_dma
[
i
]);
t
->
dcr
[
i
]
=
test_alloc
(
t
,
LABEL_SIZE
,
&
t
->
dcr_dma
[
i
]);
if
(
!
t
->
dcr
[
i
])
if
(
!
t
->
dcr
[
i
])
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -728,6 +730,7 @@ static int nfit_test1_alloc(struct nfit_test *t)
...
@@ -728,6 +730,7 @@ static int nfit_test1_alloc(struct nfit_test *t)
size_t
nfit_size
=
sizeof
(
struct
acpi_nfit_system_address
)
*
2
size_t
nfit_size
=
sizeof
(
struct
acpi_nfit_system_address
)
*
2
+
sizeof
(
struct
acpi_nfit_memory_map
)
+
sizeof
(
struct
acpi_nfit_memory_map
)
+
offsetof
(
struct
acpi_nfit_control_region
,
window_size
);
+
offsetof
(
struct
acpi_nfit_control_region
,
window_size
);
int
i
;
t
->
nfit_buf
=
test_alloc
(
t
,
nfit_size
,
&
t
->
nfit_dma
);
t
->
nfit_buf
=
test_alloc
(
t
,
nfit_size
,
&
t
->
nfit_dma
);
if
(
!
t
->
nfit_buf
)
if
(
!
t
->
nfit_buf
)
...
@@ -738,6 +741,13 @@ static int nfit_test1_alloc(struct nfit_test *t)
...
@@ -738,6 +741,13 @@ static int nfit_test1_alloc(struct nfit_test *t)
if
(
!
t
->
spa_set
[
0
])
if
(
!
t
->
spa_set
[
0
])
return
-
ENOMEM
;
return
-
ENOMEM
;
for
(
i
=
0
;
i
<
t
->
num_dcr
;
i
++
)
{
t
->
label
[
i
]
=
test_alloc
(
t
,
LABEL_SIZE
,
&
t
->
label_dma
[
i
]);
if
(
!
t
->
label
[
i
])
return
-
ENOMEM
;
sprintf
(
t
->
label
[
i
],
"label%d"
,
i
);
}
t
->
spa_set
[
1
]
=
test_alloc
(
t
,
SPA_VCD_SIZE
,
&
t
->
spa_set_dma
[
1
]);
t
->
spa_set
[
1
]
=
test_alloc
(
t
,
SPA_VCD_SIZE
,
&
t
->
spa_set_dma
[
1
]);
if
(
!
t
->
spa_set
[
1
])
if
(
!
t
->
spa_set
[
1
])
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -1450,7 +1460,7 @@ static void nfit_test1_setup(struct nfit_test *t)
...
@@ -1450,7 +1460,7 @@ static void nfit_test1_setup(struct nfit_test *t)
memdev
=
nfit_buf
+
offset
;
memdev
=
nfit_buf
+
offset
;
memdev
->
header
.
type
=
ACPI_NFIT_TYPE_MEMORY_MAP
;
memdev
->
header
.
type
=
ACPI_NFIT_TYPE_MEMORY_MAP
;
memdev
->
header
.
length
=
sizeof
(
*
memdev
);
memdev
->
header
.
length
=
sizeof
(
*
memdev
);
memdev
->
device_handle
=
0
;
memdev
->
device_handle
=
handle
[
5
]
;
memdev
->
physical_id
=
0
;
memdev
->
physical_id
=
0
;
memdev
->
region_id
=
0
;
memdev
->
region_id
=
0
;
memdev
->
range_index
=
0
+
1
;
memdev
->
range_index
=
0
+
1
;
...
@@ -1472,7 +1482,7 @@ static void nfit_test1_setup(struct nfit_test *t)
...
@@ -1472,7 +1482,7 @@ static void nfit_test1_setup(struct nfit_test *t)
window_size
);
window_size
);
dcr
->
region_index
=
0
+
1
;
dcr
->
region_index
=
0
+
1
;
dcr_common_init
(
dcr
);
dcr_common_init
(
dcr
);
dcr
->
serial_number
=
~
0
;
dcr
->
serial_number
=
~
handle
[
5
]
;
dcr
->
code
=
NFIT_FIC_BYTE
;
dcr
->
code
=
NFIT_FIC_BYTE
;
dcr
->
windows
=
0
;
dcr
->
windows
=
0
;
...
@@ -1483,6 +1493,9 @@ static void nfit_test1_setup(struct nfit_test *t)
...
@@ -1483,6 +1493,9 @@ static void nfit_test1_setup(struct nfit_test *t)
set_bit
(
ND_CMD_ARS_START
,
&
acpi_desc
->
bus_cmd_force_en
);
set_bit
(
ND_CMD_ARS_START
,
&
acpi_desc
->
bus_cmd_force_en
);
set_bit
(
ND_CMD_ARS_STATUS
,
&
acpi_desc
->
bus_cmd_force_en
);
set_bit
(
ND_CMD_ARS_STATUS
,
&
acpi_desc
->
bus_cmd_force_en
);
set_bit
(
ND_CMD_CLEAR_ERROR
,
&
acpi_desc
->
bus_cmd_force_en
);
set_bit
(
ND_CMD_CLEAR_ERROR
,
&
acpi_desc
->
bus_cmd_force_en
);
set_bit
(
ND_CMD_GET_CONFIG_SIZE
,
&
acpi_desc
->
dimm_cmd_force_en
);
set_bit
(
ND_CMD_GET_CONFIG_DATA
,
&
acpi_desc
->
dimm_cmd_force_en
);
set_bit
(
ND_CMD_SET_CONFIG_DATA
,
&
acpi_desc
->
dimm_cmd_force_en
);
}
}
static
int
nfit_test_blk_do_io
(
struct
nd_blk_region
*
ndbr
,
resource_size_t
dpa
,
static
int
nfit_test_blk_do_io
(
struct
nd_blk_region
*
ndbr
,
resource_size_t
dpa
,
...
@@ -1886,12 +1899,15 @@ static __init int nfit_test_init(void)
...
@@ -1886,12 +1899,15 @@ static __init int nfit_test_init(void)
switch
(
i
)
{
switch
(
i
)
{
case
0
:
case
0
:
nfit_test
->
num_pm
=
NUM_PM
;
nfit_test
->
num_pm
=
NUM_PM
;
nfit_test
->
dcr_idx
=
0
;
nfit_test
->
num_dcr
=
NUM_DCR
;
nfit_test
->
num_dcr
=
NUM_DCR
;
nfit_test
->
alloc
=
nfit_test0_alloc
;
nfit_test
->
alloc
=
nfit_test0_alloc
;
nfit_test
->
setup
=
nfit_test0_setup
;
nfit_test
->
setup
=
nfit_test0_setup
;
break
;
break
;
case
1
:
case
1
:
nfit_test
->
num_pm
=
1
;
nfit_test
->
num_pm
=
1
;
nfit_test
->
dcr_idx
=
NUM_DCR
;
nfit_test
->
num_dcr
=
1
;
nfit_test
->
alloc
=
nfit_test1_alloc
;
nfit_test
->
alloc
=
nfit_test1_alloc
;
nfit_test
->
setup
=
nfit_test1_setup
;
nfit_test
->
setup
=
nfit_test1_setup
;
break
;
break
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment