David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
| 2 | /* Copyright(c) 2016 - 2018 Intel Corporation. All rights reserved. */ |
| 3 | #ifndef __DAX_BUS_H__ |
| 4 | #define __DAX_BUS_H__ |
| 5 | #include <linux/device.h> |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 6 | #include <linux/range.h> |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 7 | |
| 8 | struct dev_dax; |
| 9 | struct resource; |
| 10 | struct dax_device; |
| 11 | struct dax_region; |
| 12 | void dax_region_put(struct dax_region *dax_region); |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 13 | |
| 14 | #define IORESOURCE_DAX_STATIC (1UL << 0) |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 15 | struct dax_region *alloc_dax_region(struct device *parent, int region_id, |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 16 | struct range *range, int target_node, unsigned int align, |
| 17 | unsigned long flags); |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 18 | |
| 19 | enum dev_dax_subsys { |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 20 | DEV_DAX_BUS = 0, /* zeroed dev_dax_data picks this by default */ |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 21 | DEV_DAX_CLASS, |
| 22 | }; |
| 23 | |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 24 | struct dev_dax_data { |
| 25 | struct dax_region *dax_region; |
| 26 | struct dev_pagemap *pgmap; |
| 27 | enum dev_dax_subsys subsys; |
| 28 | resource_size_t size; |
| 29 | int id; |
| 30 | }; |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 31 | |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 32 | struct dev_dax *devm_create_dev_dax(struct dev_dax_data *data); |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 33 | |
| 34 | /* to be deleted when DEV_DAX_CLASS is removed */ |
| 35 | struct dev_dax *__dax_pmem_probe(struct device *dev, enum dev_dax_subsys subsys); |
| 36 | |
| 37 | struct dax_device_driver { |
| 38 | struct device_driver drv; |
| 39 | struct list_head ids; |
| 40 | int match_always; |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 41 | int (*probe)(struct dev_dax *dev); |
| 42 | int (*remove)(struct dev_dax *dev); |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 43 | }; |
| 44 | |
| 45 | int __dax_driver_register(struct dax_device_driver *dax_drv, |
| 46 | struct module *module, const char *mod_name); |
| 47 | #define dax_driver_register(driver) \ |
| 48 | __dax_driver_register(driver, THIS_MODULE, KBUILD_MODNAME) |
| 49 | void dax_driver_unregister(struct dax_device_driver *dax_drv); |
| 50 | void kill_dev_dax(struct dev_dax *dev_dax); |
| 51 | |
| 52 | #if IS_ENABLED(CONFIG_DEV_DAX_PMEM_COMPAT) |
Olivier Deprez | 157378f | 2022-04-04 15:47:50 +0200 | [diff] [blame^] | 53 | int dev_dax_probe(struct dev_dax *dev_dax); |
David Brazdil | 0f672f6 | 2019-12-10 10:32:29 +0000 | [diff] [blame] | 54 | #endif |
| 55 | |
| 56 | /* |
| 57 | * While run_dax() is potentially a generic operation that could be |
| 58 | * defined in include/linux/dax.h we don't want to grow any users |
| 59 | * outside of drivers/dax/ |
| 60 | */ |
| 61 | void run_dax(struct dax_device *dax_dev); |
| 62 | |
| 63 | #define MODULE_ALIAS_DAX_DEVICE(type) \ |
| 64 | MODULE_ALIAS("dax:t" __stringify(type) "*") |
| 65 | #define DAX_DEVICE_MODALIAS_FMT "dax:t%d" |
| 66 | |
| 67 | #endif /* __DAX_BUS_H__ */ |