aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/gdth_proc.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/gdth_proc.c')
-rw-r--r--drivers/scsi/gdth_proc.c211
1 files changed, 48 insertions, 163 deletions
diff --git a/drivers/scsi/gdth_proc.c b/drivers/scsi/gdth_proc.c
index 652754319a4b..9fb632684863 100644
--- a/drivers/scsi/gdth_proc.c
+++ b/drivers/scsi/gdth_proc.c
@@ -5,23 +5,9 @@
5#include <linux/completion.h> 5#include <linux/completion.h>
6#include <linux/slab.h> 6#include <linux/slab.h>
7 7
8int gdth_proc_info(struct Scsi_Host *host, char *buffer,char **start,off_t offset,int length, 8int gdth_set_info(struct Scsi_Host *host, char *buffer, int length)
9 int inout)
10{ 9{
11 gdth_ha_str *ha = shost_priv(host); 10 gdth_ha_str *ha = shost_priv(host);
12
13 TRACE2(("gdth_proc_info() length %d offs %d inout %d\n",
14 length,(int)offset,inout));
15
16 if (inout)
17 return(gdth_set_info(buffer,length,host,ha));
18 else
19 return(gdth_get_info(buffer,start,offset,length,host,ha));
20}
21
22static int gdth_set_info(char *buffer,int length,struct Scsi_Host *host,
23 gdth_ha_str *ha)
24{
25 int ret_val = -EINVAL; 11 int ret_val = -EINVAL;
26 12
27 TRACE2(("gdth_set_info() ha %d\n",ha->hanum,)); 13 TRACE2(("gdth_set_info() ha %d\n",ha->hanum,));
@@ -149,12 +135,10 @@ static int gdth_set_asc_info(struct Scsi_Host *host, char *buffer,
149 return(-EINVAL); 135 return(-EINVAL);
150} 136}
151 137
152static int gdth_get_info(char *buffer,char **start,off_t offset,int length, 138int gdth_show_info(struct seq_file *m, struct Scsi_Host *host)
153 struct Scsi_Host *host, gdth_ha_str *ha)
154{ 139{
155 int size = 0,len = 0; 140 gdth_ha_str *ha = shost_priv(host);
156 int hlen; 141 int hlen;
157 off_t begin = 0,pos = 0;
158 int id, i, j, k, sec, flag; 142 int id, i, j, k, sec, flag;
159 int no_mdrv = 0, drv_no, is_mirr; 143 int no_mdrv = 0, drv_no, is_mirr;
160 u32 cnt; 144 u32 cnt;
@@ -189,8 +173,7 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
189 /* request is i.e. "cat /proc/scsi/gdth/0" */ 173 /* request is i.e. "cat /proc/scsi/gdth/0" */
190 /* format: %-15s\t%-10s\t%-15s\t%s */ 174 /* format: %-15s\t%-10s\t%-15s\t%s */
191 /* driver parameters */ 175 /* driver parameters */
192 size = sprintf(buffer+len,"Driver Parameters:\n"); 176 seq_printf(m, "Driver Parameters:\n");
193 len += size; pos = begin + len;
194 if (reserve_list[0] == 0xff) 177 if (reserve_list[0] == 0xff)
195 strcpy(hrec, "--"); 178 strcpy(hrec, "--");
196 else { 179 else {
@@ -201,69 +184,50 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
201 hlen += snprintf(hrec + hlen , 161 - hlen, ",%d", reserve_list[i]); 184 hlen += snprintf(hrec + hlen , 161 - hlen, ",%d", reserve_list[i]);
202 } 185 }
203 } 186 }
204 size = sprintf(buffer+len, 187 seq_printf(m,
205 " reserve_mode: \t%d \treserve_list: \t%s\n", 188 " reserve_mode: \t%d \treserve_list: \t%s\n",
206 reserve_mode, hrec); 189 reserve_mode, hrec);
207 len += size; pos = begin + len; 190 seq_printf(m,
208 size = sprintf(buffer+len,
209 " max_ids: \t%-3d \thdr_channel: \t%d\n", 191 " max_ids: \t%-3d \thdr_channel: \t%d\n",
210 max_ids, hdr_channel); 192 max_ids, hdr_channel);
211 len += size; pos = begin + len;
212 193
213 /* controller information */ 194 /* controller information */
214 size = sprintf(buffer+len,"\nDisk Array Controller Information:\n"); 195 seq_printf(m,"\nDisk Array Controller Information:\n");
215 len += size; pos = begin + len; 196 seq_printf(m,
216 strcpy(hrec, ha->binfo.type_string);
217 size = sprintf(buffer+len,
218 " Number: \t%d \tName: \t%s\n", 197 " Number: \t%d \tName: \t%s\n",
219 ha->hanum, hrec); 198 ha->hanum, ha->binfo.type_string);
220 len += size; pos = begin + len;
221 199
200 seq_printf(m,
201 " Driver Ver.: \t%-10s\tFirmware Ver.: \t",
202 GDTH_VERSION_STR);
222 if (ha->more_proc) 203 if (ha->more_proc)
223 sprintf(hrec, "%d.%02d.%02d-%c%03X", 204 seq_printf(m, "%d.%02d.%02d-%c%03X\n",
224 (u8)(ha->binfo.upd_fw_ver>>24), 205 (u8)(ha->binfo.upd_fw_ver>>24),
225 (u8)(ha->binfo.upd_fw_ver>>16), 206 (u8)(ha->binfo.upd_fw_ver>>16),
226 (u8)(ha->binfo.upd_fw_ver), 207 (u8)(ha->binfo.upd_fw_ver),
227 ha->bfeat.raid ? 'R':'N', 208 ha->bfeat.raid ? 'R':'N',
228 ha->binfo.upd_revision); 209 ha->binfo.upd_revision);
229 else 210 else
230 sprintf(hrec, "%d.%02d", (u8)(ha->cpar.version>>8), 211 seq_printf(m, "%d.%02d\n", (u8)(ha->cpar.version>>8),
231 (u8)(ha->cpar.version)); 212 (u8)(ha->cpar.version));
232
233 size = sprintf(buffer+len,
234 " Driver Ver.: \t%-10s\tFirmware Ver.: \t%s\n",
235 GDTH_VERSION_STR, hrec);
236 len += size; pos = begin + len;
237 213
238 if (ha->more_proc) { 214 if (ha->more_proc)
239 /* more information: 1. about controller */ 215 /* more information: 1. about controller */
240 size = sprintf(buffer+len, 216 seq_printf(m,
241 " Serial No.: \t0x%8X\tCache RAM size:\t%d KB\n", 217 " Serial No.: \t0x%8X\tCache RAM size:\t%d KB\n",
242 ha->binfo.ser_no, ha->binfo.memsize / 1024); 218 ha->binfo.ser_no, ha->binfo.memsize / 1024);
243 len += size; pos = begin + len;
244 }
245 219
246#ifdef GDTH_DMA_STATISTICS 220#ifdef GDTH_DMA_STATISTICS
247 /* controller statistics */ 221 /* controller statistics */
248 size = sprintf(buffer+len,"\nController Statistics:\n"); 222 seq_printf(m,"\nController Statistics:\n");
249 len += size; pos = begin + len; 223 seq_printf(m,
250 size = sprintf(buffer+len,
251 " 32-bit DMA buffer:\t%lu\t64-bit DMA buffer:\t%lu\n", 224 " 32-bit DMA buffer:\t%lu\t64-bit DMA buffer:\t%lu\n",
252 ha->dma32_cnt, ha->dma64_cnt); 225 ha->dma32_cnt, ha->dma64_cnt);
253 len += size; pos = begin + len;
254#endif 226#endif
255 227
256 if (pos < offset) {
257 len = 0;
258 begin = pos;
259 }
260 if (pos > offset + length)
261 goto stop_output;
262
263 if (ha->more_proc) { 228 if (ha->more_proc) {
264 /* more information: 2. about physical devices */ 229 /* more information: 2. about physical devices */
265 size = sprintf(buffer+len,"\nPhysical Devices:"); 230 seq_printf(m, "\nPhysical Devices:");
266 len += size; pos = begin + len;
267 flag = FALSE; 231 flag = FALSE;
268 232
269 buf = gdth_ioctl_alloc(ha, GDTH_SCRATCH, FALSE, &paddr); 233 buf = gdth_ioctl_alloc(ha, GDTH_SCRATCH, FALSE, &paddr);
@@ -309,21 +273,19 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
309 strncpy(hrec+8,pdi->product,16); 273 strncpy(hrec+8,pdi->product,16);
310 strncpy(hrec+24,pdi->revision,4); 274 strncpy(hrec+24,pdi->revision,4);
311 hrec[28] = 0; 275 hrec[28] = 0;
312 size = sprintf(buffer+len, 276 seq_printf(m,
313 "\n Chn/ID/LUN: \t%c/%02d/%d \tName: \t%s\n", 277 "\n Chn/ID/LUN: \t%c/%02d/%d \tName: \t%s\n",
314 'A'+i,pdi->target_id,pdi->lun,hrec); 278 'A'+i,pdi->target_id,pdi->lun,hrec);
315 len += size; pos = begin + len;
316 flag = TRUE; 279 flag = TRUE;
317 pdi->no_ldrive &= 0xffff; 280 pdi->no_ldrive &= 0xffff;
318 if (pdi->no_ldrive == 0xffff) 281 if (pdi->no_ldrive == 0xffff)
319 strcpy(hrec,"--"); 282 strcpy(hrec,"--");
320 else 283 else
321 sprintf(hrec,"%d",pdi->no_ldrive); 284 sprintf(hrec,"%d",pdi->no_ldrive);
322 size = sprintf(buffer+len, 285 seq_printf(m,
323 " Capacity [MB]:\t%-6d \tTo Log. Drive: \t%s\n", 286 " Capacity [MB]:\t%-6d \tTo Log. Drive: \t%s\n",
324 pdi->blkcnt/(1024*1024/pdi->blksize), 287 pdi->blkcnt/(1024*1024/pdi->blksize),
325 hrec); 288 hrec);
326 len += size; pos = begin + len;
327 } else { 289 } else {
328 pdi->devtype = 0xff; 290 pdi->devtype = 0xff;
329 } 291 }
@@ -333,11 +295,10 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
333 for (k = 0; k < pds->count; ++k) { 295 for (k = 0; k < pds->count; ++k) {
334 if (pds->list[k].tid == pdi->target_id && 296 if (pds->list[k].tid == pdi->target_id &&
335 pds->list[k].lun == pdi->lun) { 297 pds->list[k].lun == pdi->lun) {
336 size = sprintf(buffer+len, 298 seq_printf(m,
337 " Retries: \t%-6d \tReassigns: \t%d\n", 299 " Retries: \t%-6d \tReassigns: \t%d\n",
338 pds->list[k].retries, 300 pds->list[k].retries,
339 pds->list[k].reassigns); 301 pds->list[k].reassigns);
340 len += size; pos = begin + len;
341 break; 302 break;
342 } 303 }
343 } 304 }
@@ -355,32 +316,20 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
355 pdef->sddc_type = 0x08; 316 pdef->sddc_type = 0x08;
356 317
357 if (gdth_execute(host, gdtcmd, cmnd, 30, NULL) == S_OK) { 318 if (gdth_execute(host, gdtcmd, cmnd, 30, NULL) == S_OK) {
358 size = sprintf(buffer+len, 319 seq_printf(m,
359 " Grown Defects:\t%d\n", 320 " Grown Defects:\t%d\n",
360 pdef->sddc_cnt); 321 pdef->sddc_cnt);
361 len += size; pos = begin + len;
362 } 322 }
363 } 323 }
364 if (pos < offset) {
365 len = 0;
366 begin = pos;
367 }
368 if (pos > offset + length) {
369 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
370 goto stop_output;
371 }
372 } 324 }
373 } 325 }
374 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr); 326 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
375 327
376 if (!flag) { 328 if (!flag)
377 size = sprintf(buffer+len, "\n --\n"); 329 seq_printf(m, "\n --\n");
378 len += size; pos = begin + len;
379 }
380 330
381 /* 3. about logical drives */ 331 /* 3. about logical drives */
382 size = sprintf(buffer+len,"\nLogical Drives:"); 332 seq_printf(m,"\nLogical Drives:");
383 len += size; pos = begin + len;
384 flag = FALSE; 333 flag = FALSE;
385 334
386 buf = gdth_ioctl_alloc(ha, GDTH_SCRATCH, FALSE, &paddr); 335 buf = gdth_ioctl_alloc(ha, GDTH_SCRATCH, FALSE, &paddr);
@@ -418,10 +367,9 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
418 } 367 }
419 368
420 if (drv_no == i) { 369 if (drv_no == i) {
421 size = sprintf(buffer+len, 370 seq_printf(m,
422 "\n Number: \t%-2d \tStatus: \t%s\n", 371 "\n Number: \t%-2d \tStatus: \t%s\n",
423 drv_no, hrec); 372 drv_no, hrec);
424 len += size; pos = begin + len;
425 flag = TRUE; 373 flag = TRUE;
426 no_mdrv = pcdi->cd_ldcnt; 374 no_mdrv = pcdi->cd_ldcnt;
427 if (no_mdrv > 1 || pcdi->ld_slave != -1) { 375 if (no_mdrv > 1 || pcdi->ld_slave != -1) {
@@ -436,61 +384,37 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
436 } else { 384 } else {
437 strcpy(hrec, "???"); 385 strcpy(hrec, "???");
438 } 386 }
439 size = sprintf(buffer+len, 387 seq_printf(m,
440 " Capacity [MB]:\t%-6d \tType: \t%s\n", 388 " Capacity [MB]:\t%-6d \tType: \t%s\n",
441 pcdi->ld_blkcnt/(1024*1024/pcdi->ld_blksize), 389 pcdi->ld_blkcnt/(1024*1024/pcdi->ld_blksize),
442 hrec); 390 hrec);
443 len += size; pos = begin + len;
444 } else { 391 } else {
445 size = sprintf(buffer+len, 392 seq_printf(m,
446 " Slave Number: \t%-2d \tStatus: \t%s\n", 393 " Slave Number: \t%-2d \tStatus: \t%s\n",
447 drv_no & 0x7fff, hrec); 394 drv_no & 0x7fff, hrec);
448 len += size; pos = begin + len;
449 } 395 }
450 drv_no = pcdi->ld_slave; 396 drv_no = pcdi->ld_slave;
451 if (pos < offset) {
452 len = 0;
453 begin = pos;
454 }
455 if (pos > offset + length) {
456 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
457 goto stop_output;
458 }
459 } while (drv_no != -1); 397 } while (drv_no != -1);
460 398
461 if (is_mirr) { 399 if (is_mirr)
462 size = sprintf(buffer+len, 400 seq_printf(m,
463 " Missing Drv.: \t%-2d \tInvalid Drv.: \t%d\n", 401 " Missing Drv.: \t%-2d \tInvalid Drv.: \t%d\n",
464 no_mdrv - j - k, k); 402 no_mdrv - j - k, k);
465 len += size; pos = begin + len; 403
466 }
467
468 if (!ha->hdr[i].is_arraydrv) 404 if (!ha->hdr[i].is_arraydrv)
469 strcpy(hrec, "--"); 405 strcpy(hrec, "--");
470 else 406 else
471 sprintf(hrec, "%d", ha->hdr[i].master_no); 407 sprintf(hrec, "%d", ha->hdr[i].master_no);
472 size = sprintf(buffer+len, 408 seq_printf(m,
473 " To Array Drv.:\t%s\n", hrec); 409 " To Array Drv.:\t%s\n", hrec);
474 len += size; pos = begin + len;
475 if (pos < offset) {
476 len = 0;
477 begin = pos;
478 }
479 if (pos > offset + length) {
480 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
481 goto stop_output;
482 }
483 } 410 }
484 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr); 411 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
485 412
486 if (!flag) { 413 if (!flag)
487 size = sprintf(buffer+len, "\n --\n"); 414 seq_printf(m, "\n --\n");
488 len += size; pos = begin + len;
489 }
490 415
491 /* 4. about array drives */ 416 /* 4. about array drives */
492 size = sprintf(buffer+len,"\nArray Drives:"); 417 seq_printf(m,"\nArray Drives:");
493 len += size; pos = begin + len;
494 flag = FALSE; 418 flag = FALSE;
495 419
496 buf = gdth_ioctl_alloc(ha, GDTH_SCRATCH, FALSE, &paddr); 420 buf = gdth_ioctl_alloc(ha, GDTH_SCRATCH, FALSE, &paddr);
@@ -525,10 +449,9 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
525 strcat(hrec, "/expand"); 449 strcat(hrec, "/expand");
526 else if (pai->ai_ext_state & 0x1) 450 else if (pai->ai_ext_state & 0x1)
527 strcat(hrec, "/patch"); 451 strcat(hrec, "/patch");
528 size = sprintf(buffer+len, 452 seq_printf(m,
529 "\n Number: \t%-2d \tStatus: \t%s\n", 453 "\n Number: \t%-2d \tStatus: \t%s\n",
530 i,hrec); 454 i,hrec);
531 len += size; pos = begin + len;
532 flag = TRUE; 455 flag = TRUE;
533 456
534 if (pai->ai_type == 0) 457 if (pai->ai_type == 0)
@@ -539,31 +462,19 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
539 strcpy(hrec, "RAID-5"); 462 strcpy(hrec, "RAID-5");
540 else 463 else
541 strcpy(hrec, "RAID-10"); 464 strcpy(hrec, "RAID-10");
542 size = sprintf(buffer+len, 465 seq_printf(m,
543 " Capacity [MB]:\t%-6d \tType: \t%s\n", 466 " Capacity [MB]:\t%-6d \tType: \t%s\n",
544 pai->ai_size/(1024*1024/pai->ai_secsize), 467 pai->ai_size/(1024*1024/pai->ai_secsize),
545 hrec); 468 hrec);
546 len += size; pos = begin + len;
547 if (pos < offset) {
548 len = 0;
549 begin = pos;
550 }
551 if (pos > offset + length) {
552 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
553 goto stop_output;
554 }
555 } 469 }
556 } 470 }
557 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr); 471 gdth_ioctl_free(ha, GDTH_SCRATCH, buf, paddr);
558 472
559 if (!flag) { 473 if (!flag)
560 size = sprintf(buffer+len, "\n --\n"); 474 seq_printf(m, "\n --\n");
561 len += size; pos = begin + len;
562 }
563 475
564 /* 5. about host drives */ 476 /* 5. about host drives */
565 size = sprintf(buffer+len,"\nHost Drives:"); 477 seq_printf(m,"\nHost Drives:");
566 len += size; pos = begin + len;
567 flag = FALSE; 478 flag = FALSE;
568 479
569 buf = gdth_ioctl_alloc(ha, sizeof(gdth_hget_str), FALSE, &paddr); 480 buf = gdth_ioctl_alloc(ha, sizeof(gdth_hget_str), FALSE, &paddr);
@@ -605,33 +516,22 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
605 if (!(ha->hdr[i].present)) 516 if (!(ha->hdr[i].present))
606 continue; 517 continue;
607 518
608 size = sprintf(buffer+len, 519 seq_printf(m,
609 "\n Number: \t%-2d \tArr/Log. Drive:\t%d\n", 520 "\n Number: \t%-2d \tArr/Log. Drive:\t%d\n",
610 i, ha->hdr[i].ldr_no); 521 i, ha->hdr[i].ldr_no);
611 len += size; pos = begin + len;
612 flag = TRUE; 522 flag = TRUE;
613 523
614 size = sprintf(buffer+len, 524 seq_printf(m,
615 " Capacity [MB]:\t%-6d \tStart Sector: \t%d\n", 525 " Capacity [MB]:\t%-6d \tStart Sector: \t%d\n",
616 (u32)(ha->hdr[i].size/2048), ha->hdr[i].start_sec); 526 (u32)(ha->hdr[i].size/2048), ha->hdr[i].start_sec);
617 len += size; pos = begin + len;
618 if (pos < offset) {
619 len = 0;
620 begin = pos;
621 }
622 if (pos > offset + length)
623 goto stop_output;
624 } 527 }
625 528
626 if (!flag) { 529 if (!flag)
627 size = sprintf(buffer+len, "\n --\n"); 530 seq_printf(m, "\n --\n");
628 len += size; pos = begin + len;
629 }
630 } 531 }
631 532
632 /* controller events */ 533 /* controller events */
633 size = sprintf(buffer+len,"\nController Events:\n"); 534 seq_printf(m,"\nController Events:\n");
634 len += size; pos = begin + len;
635 535
636 for (id = -1;;) { 536 for (id = -1;;) {
637 id = gdth_read_event(ha, id, estr); 537 id = gdth_read_event(ha, id, estr);
@@ -643,29 +543,14 @@ static int gdth_get_info(char *buffer,char **start,off_t offset,int length,
643 do_gettimeofday(&tv); 543 do_gettimeofday(&tv);
644 sec = (int)(tv.tv_sec - estr->first_stamp); 544 sec = (int)(tv.tv_sec - estr->first_stamp);
645 if (sec < 0) sec = 0; 545 if (sec < 0) sec = 0;
646 size = sprintf(buffer+len," date- %02d:%02d:%02d\t%s\n", 546 seq_printf(m," date- %02d:%02d:%02d\t%s\n",
647 sec/3600, sec%3600/60, sec%60, hrec); 547 sec/3600, sec%3600/60, sec%60, hrec);
648 len += size; pos = begin + len;
649 if (pos < offset) {
650 len = 0;
651 begin = pos;
652 }
653 if (pos > offset + length)
654 goto stop_output;
655 } 548 }
656 if (id == -1) 549 if (id == -1)
657 break; 550 break;
658 } 551 }
659
660stop_output: 552stop_output:
661 *start = buffer +(offset-begin); 553 rc = 0;
662 len -= (offset-begin);
663 if (len > length)
664 len = length;
665 TRACE2(("get_info() len %d pos %d begin %d offset %d length %d size %d\n",
666 len,(int)pos,(int)begin,(int)offset,length,size));
667 rc = len;
668
669free_fail: 554free_fail:
670 kfree(gdtcmd); 555 kfree(gdtcmd);
671 kfree(estr); 556 kfree(estr);