0001
0002 #ifndef _VME_H_
0003 #define _VME_H_
0004
0005
0006 enum vme_resource_type {
0007 VME_MASTER,
0008 VME_SLAVE,
0009 VME_DMA,
0010 VME_LM
0011 };
0012
0013
0014 #define VME_A16 0x1
0015 #define VME_A24 0x2
0016 #define VME_A32 0x4
0017 #define VME_A64 0x8
0018 #define VME_CRCSR 0x10
0019 #define VME_USER1 0x20
0020 #define VME_USER2 0x40
0021 #define VME_USER3 0x80
0022 #define VME_USER4 0x100
0023
0024 #define VME_A16_MAX 0x10000ULL
0025 #define VME_A24_MAX 0x1000000ULL
0026 #define VME_A32_MAX 0x100000000ULL
0027 #define VME_A64_MAX 0x10000000000000000ULL
0028 #define VME_CRCSR_MAX 0x1000000ULL
0029
0030
0031
0032 #define VME_SCT 0x1
0033 #define VME_BLT 0x2
0034 #define VME_MBLT 0x4
0035 #define VME_2eVME 0x8
0036 #define VME_2eSST 0x10
0037 #define VME_2eSSTB 0x20
0038
0039 #define VME_2eSST160 0x100
0040 #define VME_2eSST267 0x200
0041 #define VME_2eSST320 0x400
0042
0043 #define VME_SUPER 0x1000
0044 #define VME_USER 0x2000
0045 #define VME_PROG 0x4000
0046 #define VME_DATA 0x8000
0047
0048
0049 #define VME_D8 0x1
0050 #define VME_D16 0x2
0051 #define VME_D32 0x4
0052 #define VME_D64 0x8
0053
0054
0055 #define VME_R_ROBIN_MODE 0x1
0056 #define VME_PRIORITY_MODE 0x2
0057
0058 #define VME_DMA_PATTERN (1<<0)
0059 #define VME_DMA_PCI (1<<1)
0060 #define VME_DMA_VME (1<<2)
0061
0062 #define VME_DMA_PATTERN_BYTE (1<<0)
0063 #define VME_DMA_PATTERN_WORD (1<<1)
0064 #define VME_DMA_PATTERN_INCREMENT (1<<2)
0065
0066 #define VME_DMA_VME_TO_MEM (1<<0)
0067 #define VME_DMA_MEM_TO_VME (1<<1)
0068 #define VME_DMA_VME_TO_VME (1<<2)
0069 #define VME_DMA_MEM_TO_MEM (1<<3)
0070 #define VME_DMA_PATTERN_TO_VME (1<<4)
0071 #define VME_DMA_PATTERN_TO_MEM (1<<5)
0072
0073 struct vme_dma_attr {
0074 u32 type;
0075 void *private;
0076 };
0077
0078 struct vme_resource {
0079 enum vme_resource_type type;
0080 struct list_head *entry;
0081 };
0082
0083 extern struct bus_type vme_bus_type;
0084
0085
0086 #define VME_NUM_STATUSID 256
0087
0088
0089 #define VME_MAX_BRIDGES (sizeof(unsigned int)*8)
0090 #define VME_MAX_SLOTS 32
0091
0092 #define VME_SLOT_CURRENT -1
0093 #define VME_SLOT_ALL -2
0094
0095
0096
0097
0098
0099
0100
0101
0102
0103 struct vme_dev {
0104 int num;
0105 struct vme_bridge *bridge;
0106 struct device dev;
0107 struct list_head drv_list;
0108 struct list_head bridge_list;
0109 };
0110
0111
0112
0113
0114
0115
0116
0117
0118
0119
0120
0121 struct vme_driver {
0122 const char *name;
0123 int (*match)(struct vme_dev *);
0124 int (*probe)(struct vme_dev *);
0125 void (*remove)(struct vme_dev *);
0126 struct device_driver driver;
0127 struct list_head devices;
0128 };
0129
0130 void *vme_alloc_consistent(struct vme_resource *, size_t, dma_addr_t *);
0131 void vme_free_consistent(struct vme_resource *, size_t, void *,
0132 dma_addr_t);
0133
0134 size_t vme_get_size(struct vme_resource *);
0135 int vme_check_window(u32 aspace, unsigned long long vme_base,
0136 unsigned long long size);
0137
0138 struct vme_resource *vme_slave_request(struct vme_dev *, u32, u32);
0139 int vme_slave_set(struct vme_resource *, int, unsigned long long,
0140 unsigned long long, dma_addr_t, u32, u32);
0141 int vme_slave_get(struct vme_resource *, int *, unsigned long long *,
0142 unsigned long long *, dma_addr_t *, u32 *, u32 *);
0143 void vme_slave_free(struct vme_resource *);
0144
0145 struct vme_resource *vme_master_request(struct vme_dev *, u32, u32, u32);
0146 int vme_master_set(struct vme_resource *, int, unsigned long long,
0147 unsigned long long, u32, u32, u32);
0148 int vme_master_get(struct vme_resource *, int *, unsigned long long *,
0149 unsigned long long *, u32 *, u32 *, u32 *);
0150 ssize_t vme_master_read(struct vme_resource *, void *, size_t, loff_t);
0151 ssize_t vme_master_write(struct vme_resource *, void *, size_t, loff_t);
0152 unsigned int vme_master_rmw(struct vme_resource *, unsigned int, unsigned int,
0153 unsigned int, loff_t);
0154 int vme_master_mmap(struct vme_resource *resource, struct vm_area_struct *vma);
0155 void vme_master_free(struct vme_resource *);
0156
0157 struct vme_resource *vme_dma_request(struct vme_dev *, u32);
0158 struct vme_dma_list *vme_new_dma_list(struct vme_resource *);
0159 struct vme_dma_attr *vme_dma_pattern_attribute(u32, u32);
0160 struct vme_dma_attr *vme_dma_pci_attribute(dma_addr_t);
0161 struct vme_dma_attr *vme_dma_vme_attribute(unsigned long long, u32, u32, u32);
0162 void vme_dma_free_attribute(struct vme_dma_attr *);
0163 int vme_dma_list_add(struct vme_dma_list *, struct vme_dma_attr *,
0164 struct vme_dma_attr *, size_t);
0165 int vme_dma_list_exec(struct vme_dma_list *);
0166 int vme_dma_list_free(struct vme_dma_list *);
0167 int vme_dma_free(struct vme_resource *);
0168
0169 int vme_irq_request(struct vme_dev *, int, int,
0170 void (*callback)(int, int, void *), void *);
0171 void vme_irq_free(struct vme_dev *, int, int);
0172 int vme_irq_generate(struct vme_dev *, int, int);
0173
0174 struct vme_resource *vme_lm_request(struct vme_dev *);
0175 int vme_lm_count(struct vme_resource *);
0176 int vme_lm_set(struct vme_resource *, unsigned long long, u32, u32);
0177 int vme_lm_get(struct vme_resource *, unsigned long long *, u32 *, u32 *);
0178 int vme_lm_attach(struct vme_resource *, int, void (*callback)(void *), void *);
0179 int vme_lm_detach(struct vme_resource *, int);
0180 void vme_lm_free(struct vme_resource *);
0181
0182 int vme_slot_num(struct vme_dev *);
0183 int vme_bus_num(struct vme_dev *);
0184
0185 int vme_register_driver(struct vme_driver *, unsigned int);
0186 void vme_unregister_driver(struct vme_driver *);
0187
0188
0189 #endif
0190