2020-04-22 22:50:26 +03:00
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
/*
* This is a module to test the HMM ( Heterogeneous Memory Management ) API
* of the kernel . It allows a userspace program to expose its entire address
* space through the HMM test module device file .
*/
# ifndef _LIB_TEST_HMM_UAPI_H
# define _LIB_TEST_HMM_UAPI_H
# include <linux/types.h>
# include <linux/ioctl.h>
/*
* Structure to pass to the HMM test driver to mimic a device accessing
* system memory and ZONE_DEVICE private memory through device page tables .
*
* @ addr : ( in ) user address the device will read / write
* @ ptr : ( in ) user address where device data is copied to / from
* @ npages : ( in ) number of pages to read / write
* @ cpages : ( out ) number of pages copied
* @ faults : ( out ) number of device page faults seen
*/
struct hmm_dmirror_cmd {
__u64 addr ;
__u64 ptr ;
__u64 npages ;
__u64 cpages ;
__u64 faults ;
} ;
/* Expose the address space of the calling process through hmm device file */
# define HMM_DMIRROR_READ _IOWR('H', 0x00, struct hmm_dmirror_cmd)
# define HMM_DMIRROR_WRITE _IOWR('H', 0x01, struct hmm_dmirror_cmd)
2022-07-15 18:05:15 +03:00
# define HMM_DMIRROR_MIGRATE_TO_DEV _IOWR('H', 0x02, struct hmm_dmirror_cmd)
# define HMM_DMIRROR_MIGRATE_TO_SYS _IOWR('H', 0x03, struct hmm_dmirror_cmd)
# define HMM_DMIRROR_SNAPSHOT _IOWR('H', 0x04, struct hmm_dmirror_cmd)
# define HMM_DMIRROR_EXCLUSIVE _IOWR('H', 0x05, struct hmm_dmirror_cmd)
# define HMM_DMIRROR_CHECK_EXCLUSIVE _IOWR('H', 0x06, struct hmm_dmirror_cmd)
2020-04-22 22:50:26 +03:00
/*
* Values returned in hmm_dmirror_cmd . ptr for HMM_DMIRROR_SNAPSHOT .
* HMM_DMIRROR_PROT_ERROR : no valid mirror PTE for this page
* HMM_DMIRROR_PROT_NONE : unpopulated PTE or PTE with no access
* HMM_DMIRROR_PROT_READ : read - only PTE
* HMM_DMIRROR_PROT_WRITE : read / write PTE
2020-07-02 01:53:52 +03:00
* HMM_DMIRROR_PROT_PMD : PMD sized page is fully mapped by same permissions
* HMM_DMIRROR_PROT_PUD : PUD sized page is fully mapped by same permissions
2020-04-22 22:50:26 +03:00
* HMM_DMIRROR_PROT_ZERO : special read - only zero page
* HMM_DMIRROR_PROT_DEV_PRIVATE_LOCAL : Migrated device private page on the
* device the ioctl ( ) is made
* HMM_DMIRROR_PROT_DEV_PRIVATE_REMOTE : Migrated device private page on some
* other device
2022-07-15 18:05:17 +03:00
* HMM_DMIRROR_PROT_DEV_COHERENT : Migrate device coherent page on the device
* the ioctl ( ) is made
2020-04-22 22:50:26 +03:00
*/
enum {
HMM_DMIRROR_PROT_ERROR = 0xFF ,
HMM_DMIRROR_PROT_NONE = 0x00 ,
HMM_DMIRROR_PROT_READ = 0x01 ,
HMM_DMIRROR_PROT_WRITE = 0x02 ,
2020-07-02 01:53:52 +03:00
HMM_DMIRROR_PROT_PMD = 0x04 ,
HMM_DMIRROR_PROT_PUD = 0x08 ,
2020-04-22 22:50:26 +03:00
HMM_DMIRROR_PROT_ZERO = 0x10 ,
HMM_DMIRROR_PROT_DEV_PRIVATE_LOCAL = 0x20 ,
HMM_DMIRROR_PROT_DEV_PRIVATE_REMOTE = 0x30 ,
2022-07-15 18:05:17 +03:00
HMM_DMIRROR_PROT_DEV_COHERENT_LOCAL = 0x40 ,
HMM_DMIRROR_PROT_DEV_COHERENT_REMOTE = 0x50 ,
2020-04-22 22:50:26 +03:00
} ;
2022-07-15 18:05:15 +03:00
enum {
/* 0 is reserved to catch uninitialized type fields */
HMM_DMIRROR_MEMORY_DEVICE_PRIVATE = 1 ,
2022-07-15 18:05:16 +03:00
HMM_DMIRROR_MEMORY_DEVICE_COHERENT ,
2022-07-15 18:05:15 +03:00
} ;
2020-04-22 22:50:26 +03:00
# endif /* _LIB_TEST_HMM_UAPI_H */