2019-05-29 07:18:09 -07:00
/* SPDX-License-Identifier: GPL-2.0-only */
2017-04-07 15:33:36 -07:00
/*
* Copyright ( c ) 2016 Intel Corporation . All rights reserved .
*/
# ifndef __DAX_PRIVATE_H__
# define __DAX_PRIVATE_H__
# include <linux/device.h>
# include <linux/cdev.h>
2017-07-12 17:58:21 -07:00
/* private routines between core files */
struct dax_device ;
struct dax_device * inode_dax ( struct inode * inode ) ;
struct inode * dax_inode ( struct dax_device * dax_dev ) ;
2017-07-12 17:58:21 -07:00
int dax_bus_init ( void ) ;
void dax_bus_exit ( void ) ;
2017-07-12 17:58:21 -07:00
2017-04-07 15:33:36 -07:00
/**
* struct dax_region - mapping infrastructure for dax devices
* @ id : kernel - wide unique region for a memory range
2018-11-09 12:43:07 -08:00
* @ target_node : effective numa node if this memory range is onlined
2017-04-07 15:33:36 -07:00
* @ kref : to pin while other agents have a need to do lookups
* @ dev : parent device backing this region
* @ align : allocation and mapping alignment for child dax devices
* @ res : physical address range of the region
* @ pfn_flags : identify whether the pfns are paged back or not
*/
struct dax_region {
int id ;
2018-11-09 12:43:07 -08:00
int target_node ;
2017-04-07 15:33:36 -07:00
struct kref kref ;
struct device * dev ;
unsigned int align ;
struct resource res ;
2019-11-06 17:43:37 -08:00
unsigned long long pfn_flags ;
2017-04-07 15:33:36 -07:00
} ;
/**
2018-10-29 15:52:42 -07:00
* struct dev_dax - instance data for a subdivision of a dax region , and
* data while the device is activated in the driver .
2017-04-07 15:33:36 -07:00
* @ region - parent region
2017-05-04 23:38:43 -07:00
* @ dax_dev - core dax functionality
2018-11-09 12:43:07 -08:00
* @ target_node : effective numa node if dev_dax memory range is onlined
2017-05-04 23:38:43 -07:00
* @ dev - device core
2018-10-29 15:52:42 -07:00
* @ pgmap - pgmap for memmap setup / lifetime ( driver owned )
2019-07-16 16:30:35 -07:00
* @ dax_mem_res : physical address range of hotadded DAX memory
2020-06-04 16:48:48 -07:00
* @ dax_mem_name : name for hotadded DAX memory via add_memory_driver_managed ( )
2017-04-07 15:33:36 -07:00
*/
2017-05-04 23:38:43 -07:00
struct dev_dax {
2017-04-07 15:33:36 -07:00
struct dax_region * region ;
2017-05-04 23:38:43 -07:00
struct dax_device * dax_dev ;
2018-11-09 12:43:07 -08:00
int target_node ;
2017-04-07 15:33:36 -07:00
struct device dev ;
2018-10-29 15:52:42 -07:00
struct dev_pagemap pgmap ;
2019-07-16 16:30:35 -07:00
struct resource * dax_kmem_res ;
2017-04-07 15:33:36 -07:00
} ;
2017-07-12 17:58:21 -07:00
static inline struct dev_dax * to_dev_dax ( struct device * dev )
{
return container_of ( dev , struct dev_dax , dev ) ;
}
2017-04-07 15:33:36 -07:00
# endif