Blame view

drivers/scsi/scsi_trace.c 6.6 KB
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
  /*
   * Copyright (C) 2010 FUJITSU LIMITED
   * Copyright (C) 2010 Tomohiro Kusumi <kusumi.tomohiro@jp.fujitsu.com>
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   *
   * This program is distributed in the hope that 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
   */
  #include <linux/kernel.h>
  #include <linux/trace_seq.h>
  #include <trace/events/scsi.h>
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
21
22
  #define SERVICE_ACTION16(cdb) (cdb[1] & 0x1f)
  #define SERVICE_ACTION32(cdb) ((cdb[8] << 8) | cdb[9])
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
23
24
25
26
27
28
29
  
  static const char *
  scsi_trace_misc(struct trace_seq *, unsigned char *, int);
  
  static const char *
  scsi_trace_rw6(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
30
  	const char *ret = trace_seq_buffer_ptr(p);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
  	sector_t lba = 0, txlen = 0;
  
  	lba |= ((cdb[1] & 0x1F) << 16);
  	lba |=  (cdb[2] << 8);
  	lba |=   cdb[3];
  	txlen = cdb[4];
  
  	trace_seq_printf(p, "lba=%llu txlen=%llu",
  			 (unsigned long long)lba, (unsigned long long)txlen);
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_rw10(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
48
  	const char *ret = trace_seq_buffer_ptr(p);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
49
50
51
52
53
54
55
56
  	sector_t lba = 0, txlen = 0;
  
  	lba |= (cdb[2] << 24);
  	lba |= (cdb[3] << 16);
  	lba |= (cdb[4] << 8);
  	lba |=  cdb[5];
  	txlen |= (cdb[7] << 8);
  	txlen |=  cdb[8];
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
57
58
59
  	trace_seq_printf(p, "lba=%llu txlen=%llu protect=%u",
  			 (unsigned long long)lba, (unsigned long long)txlen,
  			 cdb[1] >> 5);
c498bf1a1   Martin K. Petersen   [SCSI] scsi_trace...
60
61
62
  
  	if (cdb[0] == WRITE_SAME)
  		trace_seq_printf(p, " unmap=%u", cdb[1] >> 3 & 1);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
63
64
65
66
67
68
69
70
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_rw12(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
71
  	const char *ret = trace_seq_buffer_ptr(p);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
72
73
74
75
76
77
78
79
80
81
  	sector_t lba = 0, txlen = 0;
  
  	lba |= (cdb[2] << 24);
  	lba |= (cdb[3] << 16);
  	lba |= (cdb[4] << 8);
  	lba |=  cdb[5];
  	txlen |= (cdb[6] << 24);
  	txlen |= (cdb[7] << 16);
  	txlen |= (cdb[8] << 8);
  	txlen |=  cdb[9];
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
82
83
84
  	trace_seq_printf(p, "lba=%llu txlen=%llu protect=%u",
  			 (unsigned long long)lba, (unsigned long long)txlen,
  			 cdb[1] >> 5);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
85
86
87
88
89
90
91
92
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_rw16(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
93
  	const char *ret = trace_seq_buffer_ptr(p);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
94
95
96
97
98
99
100
101
102
103
104
105
106
107
  	sector_t lba = 0, txlen = 0;
  
  	lba |= ((u64)cdb[2] << 56);
  	lba |= ((u64)cdb[3] << 48);
  	lba |= ((u64)cdb[4] << 40);
  	lba |= ((u64)cdb[5] << 32);
  	lba |= (cdb[6] << 24);
  	lba |= (cdb[7] << 16);
  	lba |= (cdb[8] << 8);
  	lba |=  cdb[9];
  	txlen |= (cdb[10] << 24);
  	txlen |= (cdb[11] << 16);
  	txlen |= (cdb[12] << 8);
  	txlen |=  cdb[13];
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
108
109
110
111
112
113
  	trace_seq_printf(p, "lba=%llu txlen=%llu protect=%u",
  			 (unsigned long long)lba, (unsigned long long)txlen,
  			 cdb[1] >> 5);
  
  	if (cdb[0] == WRITE_SAME_16)
  		trace_seq_printf(p, " unmap=%u", cdb[1] >> 3 & 1);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
114
115
116
117
118
119
120
121
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_rw32(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
122
  	const char *ret = trace_seq_buffer_ptr(p), *cmd;
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
123
  	sector_t lba = 0, txlen = 0;
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
  	u32 ei_lbrt = 0;
  
  	switch (SERVICE_ACTION32(cdb)) {
  	case READ_32:
  		cmd = "READ";
  		break;
  	case VERIFY_32:
  		cmd = "VERIFY";
  		break;
  	case WRITE_32:
  		cmd = "WRITE";
  		break;
  	case WRITE_SAME_32:
  		cmd = "WRITE_SAME";
  		break;
  	default:
91c40f24f   Rasmus Villemoes   scsi: replace seq...
140
  		trace_seq_puts(p, "UNKNOWN");
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
141
142
  		goto out;
  	}
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
143
144
145
146
147
148
149
150
151
  
  	lba |= ((u64)cdb[12] << 56);
  	lba |= ((u64)cdb[13] << 48);
  	lba |= ((u64)cdb[14] << 40);
  	lba |= ((u64)cdb[15] << 32);
  	lba |= (cdb[16] << 24);
  	lba |= (cdb[17] << 16);
  	lba |= (cdb[18] << 8);
  	lba |=  cdb[19];
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
152
153
154
155
  	ei_lbrt |= (cdb[20] << 24);
  	ei_lbrt |= (cdb[21] << 16);
  	ei_lbrt |= (cdb[22] << 8);
  	ei_lbrt |=  cdb[23];
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
156
157
158
159
  	txlen |= (cdb[28] << 24);
  	txlen |= (cdb[29] << 16);
  	txlen |= (cdb[30] << 8);
  	txlen |=  cdb[31];
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
  	trace_seq_printf(p, "%s_32 lba=%llu txlen=%llu protect=%u ei_lbrt=%u",
  			 cmd, (unsigned long long)lba,
  			 (unsigned long long)txlen, cdb[10] >> 5, ei_lbrt);
  
  	if (SERVICE_ACTION32(cdb) == WRITE_SAME_32)
  		trace_seq_printf(p, " unmap=%u", cdb[10] >> 3 & 1);
  
  out:
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_unmap(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
176
  	const char *ret = trace_seq_buffer_ptr(p);
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
177
178
179
180
181
182
183
184
185
186
187
  	unsigned int regions = cdb[7] << 8 | cdb[8];
  
  	trace_seq_printf(p, "regions=%u", (regions - 8) / 16);
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_service_action_in(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
188
  	const char *ret = trace_seq_buffer_ptr(p), *cmd;
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
189
190
191
192
193
194
195
196
197
198
199
  	sector_t lba = 0;
  	u32 alloc_len = 0;
  
  	switch (SERVICE_ACTION16(cdb)) {
  	case SAI_READ_CAPACITY_16:
  		cmd = "READ_CAPACITY_16";
  		break;
  	case SAI_GET_LBA_STATUS:
  		cmd = "GET_LBA_STATUS";
  		break;
  	default:
91c40f24f   Rasmus Villemoes   scsi: replace seq...
200
  		trace_seq_puts(p, "UNKNOWN");
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
  		goto out;
  	}
  
  	lba |= ((u64)cdb[2] << 56);
  	lba |= ((u64)cdb[3] << 48);
  	lba |= ((u64)cdb[4] << 40);
  	lba |= ((u64)cdb[5] << 32);
  	lba |= (cdb[6] << 24);
  	lba |= (cdb[7] << 16);
  	lba |= (cdb[8] << 8);
  	lba |=  cdb[9];
  	alloc_len |= (cdb[10] << 24);
  	alloc_len |= (cdb[11] << 16);
  	alloc_len |= (cdb[12] << 8);
  	alloc_len |=  cdb[13];
  
  	trace_seq_printf(p, "%s lba=%llu alloc_len=%u", cmd,
  			 (unsigned long long)lba, alloc_len);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
219

c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
220
  out:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
221
222
223
224
225
226
227
228
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  static const char *
  scsi_trace_varlen(struct trace_seq *p, unsigned char *cdb, int len)
  {
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
229
  	switch (SERVICE_ACTION32(cdb)) {
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
230
  	case READ_32:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
231
  	case VERIFY_32:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
232
  	case WRITE_32:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
233
  	case WRITE_SAME_32:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
234
235
236
237
238
239
240
241
242
  		return scsi_trace_rw32(p, cdb, len);
  	default:
  		return scsi_trace_misc(p, cdb, len);
  	}
  }
  
  static const char *
  scsi_trace_misc(struct trace_seq *p, unsigned char *cdb, int len)
  {
7b039cb4c   Steven Rostedt (Red Hat)   tracing: Add trac...
243
  	const char *ret = trace_seq_buffer_ptr(p);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
244

f50332ff2   Rasmus Villemoes   scsi: print singl...
245
  	trace_seq_putc(p, '-');
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
246
247
248
249
250
251
252
253
254
255
256
257
258
  	trace_seq_putc(p, 0);
  
  	return ret;
  }
  
  const char *
  scsi_trace_parse_cdb(struct trace_seq *p, unsigned char *cdb, int len)
  {
  	switch (cdb[0]) {
  	case READ_6:
  	case WRITE_6:
  		return scsi_trace_rw6(p, cdb, len);
  	case READ_10:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
259
  	case VERIFY:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
260
  	case WRITE_10:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
261
  	case WRITE_SAME:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
262
263
  		return scsi_trace_rw10(p, cdb, len);
  	case READ_12:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
264
  	case VERIFY_12:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
265
266
267
  	case WRITE_12:
  		return scsi_trace_rw12(p, cdb, len);
  	case READ_16:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
268
  	case VERIFY_16:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
269
  	case WRITE_16:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
270
  	case WRITE_SAME_16:
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
271
  		return scsi_trace_rw16(p, cdb, len);
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
272
273
  	case UNMAP:
  		return scsi_trace_unmap(p, cdb, len);
eb846d9f1   Hannes Reinecke   scsi: rename SERV...
274
  	case SERVICE_ACTION_IN_16:
c446c1f99   Martin K. Petersen   [SCSI] scsi_trace...
275
  		return scsi_trace_service_action_in(p, cdb, len);
bf8162354   Kei Tokunaga   [SCSI] add scsi t...
276
277
278
279
280
281
  	case VARIABLE_LENGTH_CMD:
  		return scsi_trace_varlen(p, cdb, len);
  	default:
  		return scsi_trace_misc(p, cdb, len);
  	}
  }