hc
2023-03-21 4b55d97acc464242bcd6a8ae77b8ff37c22dec58
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _VME_USER_H_
#define _VME_USER_H_
 
#define VME_USER_BUS_MAX    1
 
/*
 * VMEbus Master Window Configuration Structure
 */
struct vme_master {
   __u32 enable;        /* State of Window */
   __u64 vme_addr;        /* Starting Address on the VMEbus */
   __u64 size;        /* Window Size */
   __u32 aspace;        /* Address Space */
   __u32 cycle;        /* Cycle properties */
   __u32 dwidth;        /* Maximum Data Width */
#if 0
   char prefetchenable;        /* Prefetch Read Enable State */
   int prefetchsize;        /* Prefetch Read Size (Cache Lines) */
   char wrpostenable;        /* Write Post State */
#endif
} __packed;
 
/*
 * IOCTL Commands and structures
 */
 
/* Magic number for use in ioctls */
#define VME_IOC_MAGIC 0xAE
 
/* VMEbus Slave Window Configuration Structure */
struct vme_slave {
   __u32 enable;        /* State of Window */
   __u64 vme_addr;        /* Starting Address on the VMEbus */
   __u64 size;        /* Window Size */
   __u32 aspace;        /* Address Space */
   __u32 cycle;        /* Cycle properties */
#if 0
   char wrpostenable;        /* Write Post State */
   char rmwlock;            /* Lock PCI during RMW Cycles */
   char data64bitcapable;        /* non-VMEbus capable of 64-bit Data */
#endif
} __packed;
 
struct vme_irq_id {
   __u8 level;
   __u8 statid;
};
 
#define VME_GET_SLAVE _IOR(VME_IOC_MAGIC, 1, struct vme_slave)
#define VME_SET_SLAVE _IOW(VME_IOC_MAGIC, 2, struct vme_slave)
#define VME_GET_MASTER _IOR(VME_IOC_MAGIC, 3, struct vme_master)
#define VME_SET_MASTER _IOW(VME_IOC_MAGIC, 4, struct vme_master)
#define VME_IRQ_GEN _IOW(VME_IOC_MAGIC, 5, struct vme_irq_id)
 
#endif /* _VME_USER_H_ */