forked from nvmecompliance/dnvme
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdnvme_queue.h
executable file
·219 lines (195 loc) · 6.65 KB
/
dnvme_queue.h
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
/*
* NVM Express Compliance Suite
* Copyright (c) 2011, Intel Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef _DNVME_QUEUE_H_
#define _DNVME_QUEUE_H_
#include "dnvme_reg.h"
#include "dnvme_ds.h"
#include "sysfuncproto.h"
/* Admin SQ tail Door bell offset */
#define NVME_SQ0TBDL 0x1000
/* Admin SQ size Mask bits 0-11 in AQA */
#define ASQS_MASK 0xFFF
/* Admin Completion Q Mask Bits 16-21 in ADA */
#define ACQS_MASK 0x0FFF0000
/* As Time Out is in lower 32 bits of 64 bit CAP */
#define NVME_TO_SHIFT_MASK 24
/* CAP.TO field units */
#define CAP_TO_UNIT 500
/*
* Maximum AQ entries allowed.
*/
#define MAX_AQ_ENTRIES 4096
/*
* Enumerating the different NVME Controller Capabilities of the
* PCI Express device as per NVME Spec 1.0b.
*/
enum {
NVME_CC_ENABLE = 1 << 0,
NVME_CC_CSS_NVM = 0 << 4,
NVME_CC_MPS_SHIFT = 7,
NVME_CC_ARB_RR = 0 << 11,
NVME_CC_ARB_WRRU = 1 << 11,
NVME_CC_ARB_VS = 3 << 11,
NVME_CC_SHN_NONE = 0 << 13,
NVME_CC_SHN_NORMAL = 1 << 13,
NVME_CC_SHN_ABRUPT = 2 << 13,
NVME_CSTS_RDY = 1 << 0,
NVME_CSTS_CFS = 1 << 1,
NVME_CSTS_SHST_NORMAL = 0 << 2,
NVME_CSTS_SHST_OCCUR = 1 << 2,
NVME_CSTS_SHST_CMPLT = 2 << 2,
};
/*
* completion q entry structure.
*/
struct cq_completion {
u32 cmd_specifc; /* DW 0 all 32 bits */
u32 reserved; /* DW 1 all 32 bits */
u16 sq_head_ptr; /* DW 2 lower 16 bits */
u16 sq_identifier; /* DW 2 higher 16 bits */
u16 cmd_identifier; /* Cmd identifier */
u8 phase_bit:1; /* Phase bit */
u16 status_field:15; /* Status field */
};
/**
* The user selection of IOCTL for creating admin cq eventually calls
* this function if init is successful. This will create infrastructure
* for Admin Completion Q creation
* @param pnvme_dev
* @param qsize
* @param pmetrics_cq_list
* @return whether ACQ creation successful or not.
*/
int create_admn_cq(struct nvme_device *pnvme_dev, u32 qsize,
struct metrics_cq *pmetrics_cq_list);
/**
* The user selection of IOCTL for creating admin sq eventually calls
* this function if init is successful. This will create infrastructure
* for Admin Submission Q creation
* @param pnvme_dev
* @param qsize
* @param pmetrics_sq_list
* @return whether ASQ creation successful or not.
*/
int create_admn_sq(struct nvme_device *pnvme_dev, u32 qsize,
struct metrics_sq *pmetrics_sq_list);
/*
* nvme_ctrl_set_state - NVME controller enable/disable function. This will
* set the CAP.EN flag to the given state value and this function which call
* the timer handler and check for the timer expiration. It returns success if
* the ctrl transitions rdy before timeout.
* @param pmetrics_device
* @param state the state to set to
* @return SUCCESS or FAIL
*/
int nvme_ctrl_set_state(struct metrics_device_list *pmetrics_device, u8 state);
/**
* device_cleanup - Will clean up all the existing data structs used by driver
* @param pmetrics_device
* @param new_state
*/
void device_cleanup(struct metrics_device_list *pmetrics_device,
enum nvme_state new_state);
/**
* identify_unique - verify if the q_id specified is unique. If not unique then
* return fail.
* @param q_id
* @param type
* @param pmetrics_device
* @return SUCCESS or FAIL
*/
int identify_unique(u16 q_id, enum metrics_type type,
struct metrics_device_list *pmetrics_device);
/**
* nvme_prepare_sq - NVME controller prepare sq function. This will check
* if q is allocated and then create a memory for the IO SQ.
* @param pmetrics_sq_list
* @param pnvme_dev
* @return SUCCESS or FAIL
*/
int nvme_prepare_sq(struct metrics_sq *pmetrics_sq_list,
struct nvme_device *pnvme_dev);
/**
* nvme_prepare_cq - NVME controller prepare cq function. This will check
* if q is allocated and then create a memory for the IO SQ.
* @param pmetrics_cq_list
* @param pnvme_dev
* @return SUCCESS or FAIL
*/
int nvme_prepare_cq(struct metrics_cq *pmetrics_cq_list,
struct nvme_device *pnvme_dev);
/**
* nvme_ring_sqx_dbl - NVME controller function to ring the appropriate
* SQ doorbell.
* @param ring_sqx
* @param pmetrics_device
* @return SUCCESS or FAIL
*/
int nvme_ring_sqx_dbl(u16 ring_sqx, struct metrics_device_list
*pmetrics_device);
/**
* finds the sq node in the given sq list for the given sq id
* @param pmetrics_device
* @param sq_id
* @return pointer to the sq node for given sq id
*/
struct metrics_sq *find_sq(struct metrics_device_list
*pmetrics_device, u16 sq_id);
/**
* finds the cq node in the given cq list for the given cq id
* @param pmetrics_device
* @param cq_id
* @return pointer to the cq node for given cq id
*/
struct metrics_cq *find_cq(struct metrics_device_list
*pmetrics_device, u16 cq_id);
/**
* Find the command node for the given sq node and cmd id.
* @param pmetrics_sq_node
* @param cmd_id
* @return pointer to cmd node for given cmd id.
*/
struct cmd_track *find_cmd(struct metrics_sq *pmetrics_sq_node, u16 cmd_id);
/**
* Find meta data node for the given meda id and device.
* @param pmetrics_device
* @param meta_id
* @return pointer to metrics_meta node.
*/
struct metrics_meta *find_meta_node(struct metrics_device_list
*pmetrics_device, u32 meta_id);
/**
* This function gives the device metrics when the user requests. This
* routine works with Add Q's including Admin and IO.
* Assumes user allocated buffer memory to copy accordingly.
* @param get_q_metrics
* @param pmetrics_device
* @return success or failure.
*/
int get_public_qmetrics(struct metrics_device_list *pmetrics_device,
struct nvme_get_q_metrics *get_q_metrics);
/**
* reap_inquiry - This generic function will try to inquire the number of
* CE entries in the Completion Queue that are waiting to be reaped for any
* given q_id.
* @param pmetrics_cq_node
* @param dev
* @return number of CE's remaining
*/
u32 reap_inquiry(struct metrics_cq *pmetrics_cq_node, struct device *dev);
#endif