2016-06-18 02:08:06 +08:00
|
|
|
#ifndef __NVDIMM_PMEM_H__
|
|
|
|
#define __NVDIMM_PMEM_H__
|
|
|
|
#include <linux/badblocks.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/pfn_t.h>
|
|
|
|
#include <linux/fs.h>
|
|
|
|
|
2017-05-30 13:40:44 +08:00
|
|
|
#ifdef CONFIG_ARCH_HAS_PMEM_API
|
2017-01-14 12:36:58 +08:00
|
|
|
#define ARCH_MEMREMAP_PMEM MEMREMAP_WB
|
2017-05-30 13:40:44 +08:00
|
|
|
void arch_wb_cache_pmem(void *addr, size_t size);
|
2017-05-30 14:00:34 +08:00
|
|
|
void arch_invalidate_pmem(void *addr, size_t size);
|
2017-05-30 13:40:44 +08:00
|
|
|
#else
|
2017-01-14 12:36:58 +08:00
|
|
|
#define ARCH_MEMREMAP_PMEM MEMREMAP_WT
|
2017-05-30 13:40:44 +08:00
|
|
|
static inline void arch_wb_cache_pmem(void *addr, size_t size)
|
|
|
|
{
|
|
|
|
}
|
2017-05-30 14:00:34 +08:00
|
|
|
static inline void arch_invalidate_pmem(void *addr, size_t size)
|
|
|
|
{
|
|
|
|
}
|
2017-05-30 13:40:44 +08:00
|
|
|
#endif
|
|
|
|
|
2016-06-18 02:08:06 +08:00
|
|
|
/* this definition is in it's own header for tools/testing/nvdimm to consume */
|
|
|
|
struct pmem_device {
|
|
|
|
/* One contiguous memory region per device */
|
|
|
|
phys_addr_t phys_addr;
|
|
|
|
/* when non-zero this device is hosting a 'pfn' instance */
|
|
|
|
phys_addr_t data_offset;
|
|
|
|
u64 pfn_flags;
|
2016-06-04 09:06:47 +08:00
|
|
|
void *virt_addr;
|
2016-06-18 02:08:06 +08:00
|
|
|
/* immutable base size of the namespace */
|
|
|
|
size_t size;
|
|
|
|
/* trim size when namespace capacity has been section aligned */
|
|
|
|
u32 pfn_pad;
|
2017-06-13 06:25:11 +08:00
|
|
|
struct kernfs_node *bb_state;
|
2016-06-18 02:08:06 +08:00
|
|
|
struct badblocks bb;
|
2017-01-25 15:02:09 +08:00
|
|
|
struct dax_device *dax_dev;
|
|
|
|
struct gendisk *disk;
|
2016-06-18 02:08:06 +08:00
|
|
|
};
|
2017-01-25 15:02:09 +08:00
|
|
|
|
|
|
|
long __pmem_direct_access(struct pmem_device *pmem, pgoff_t pgoff,
|
|
|
|
long nr_pages, void **kaddr, pfn_t *pfn);
|
2016-06-18 02:08:06 +08:00
|
|
|
#endif /* __NVDIMM_PMEM_H__ */
|