This source file includes following definitions.
- sr_release
- check_cdrom_media_change
- rw_intr
- sr_photocd_done
- sr_photocd
- sr_open
- do_sr_request
- requeue_sr_request
- sr_detect
- sr_attach
- sr_init_done
- get_sectorsize
- sr_init
- sr_finish
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 #include <linux/fs.h>
18 #include <linux/kernel.h>
19 #include <linux/sched.h>
20 #include <linux/string.h>
21 #include <linux/errno.h>
22 #include <linux/cdrom.h>
23 #include <asm/system.h>
24
25 #define MAJOR_NR SCSI_CDROM_MAJOR
26 #include "../block/blk.h"
27 #include "scsi.h"
28 #include "hosts.h"
29 #include "sr.h"
30 #include "scsi_ioctl.h"
31 #include "constants.h"
32
33 #define MAX_RETRIES 3
34 #define SR_TIMEOUT 5000
35
36 static void sr_init(void);
37 static void sr_finish(void);
38 static void sr_attach(Scsi_Device *);
39 static int sr_detect(Scsi_Device *);
40
41 struct Scsi_Device_Template sr_template = {NULL, "cdrom", "sr", TYPE_ROM,
42 SCSI_CDROM_MAJOR, 0, 0, 0, 1,
43 sr_detect, sr_init,
44 sr_finish, sr_attach, NULL};
45
46 Scsi_CD * scsi_CDs;
47 static int * sr_sizes;
48
49 static int * sr_blocksizes;
50
51 static int sr_open(struct inode *, struct file *);
52 static void get_sectorsize(int);
53
54 extern int sr_ioctl(struct inode *, struct file *, unsigned int, unsigned long);
55
56 void requeue_sr_request (Scsi_Cmnd * SCpnt);
57 static int check_cdrom_media_change(dev_t);
58
59 static void sr_release(struct inode * inode, struct file * file)
60 {
61 sync_dev(inode->i_rdev);
62 if(! --scsi_CDs[MINOR(inode->i_rdev)].device->access_count)
63 sr_ioctl(inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0);
64 }
65
66 static struct file_operations sr_fops =
67 {
68 NULL,
69 block_read,
70 block_write,
71 NULL,
72 NULL,
73 sr_ioctl,
74 NULL,
75 sr_open,
76 sr_release,
77 NULL,
78 NULL,
79 check_cdrom_media_change,
80 NULL
81 };
82
83
84
85
86
87
88
89
90
91
92
93 int check_cdrom_media_change(dev_t full_dev){
94 int retval, target;
95 struct inode inode;
96 int flag = 0;
97
98 target = MINOR(full_dev);
99
100 if (target >= sr_template.nr_dev) {
101 printk("CD-ROM request error: invalid device.\n");
102 return 0;
103 };
104
105 inode.i_rdev = full_dev;
106 retval = sr_ioctl(&inode, NULL, SCSI_IOCTL_TEST_UNIT_READY, 0);
107
108 if(retval){
109
110
111
112
113 scsi_CDs[target].device->changed = 1;
114 return 1;
115
116 };
117
118 retval = scsi_CDs[target].device->changed;
119 if(!flag) {
120 scsi_CDs[target].device->changed = 0;
121
122
123 if (retval) scsi_CDs[target].needs_sector_size = 1;
124 };
125 return retval;
126 }
127
128
129
130
131
132
133 static void rw_intr (Scsi_Cmnd * SCpnt)
134 {
135 int result = SCpnt->result;
136 int this_count = SCpnt->this_count;
137
138 #ifdef DEBUG
139 printk("sr.c done: %x %x\n",result, SCpnt->request.bh->b_data);
140 #endif
141 if (!result)
142 {
143 if (SCpnt->use_sg == 0) {
144 if (SCpnt->buffer != SCpnt->request.buffer)
145 {
146 int offset;
147 offset = (SCpnt->request.sector % 4) << 9;
148 memcpy((char *)SCpnt->request.buffer,
149 (char *)SCpnt->buffer + offset,
150 this_count << 9);
151
152
153
154
155 if((offset == 0) && this_count == 2 &&
156 SCpnt->request.nr_sectors > this_count &&
157 SCpnt->request.bh &&
158 SCpnt->request.bh->b_reqnext &&
159 SCpnt->request.bh->b_reqnext->b_size == 1024) {
160 memcpy((char *)SCpnt->request.bh->b_reqnext->b_data,
161 (char *)SCpnt->buffer + 1024,
162 1024);
163 this_count += 2;
164 };
165
166 scsi_free(SCpnt->buffer, 2048);
167 }
168 } else {
169 struct scatterlist * sgpnt;
170 int i;
171 sgpnt = (struct scatterlist *) SCpnt->buffer;
172 for(i=0; i<SCpnt->use_sg; i++) {
173 if (sgpnt[i].alt_address) {
174 if (sgpnt[i].alt_address != sgpnt[i].address) {
175 memcpy(sgpnt[i].alt_address, sgpnt[i].address, sgpnt[i].length);
176 };
177 scsi_free(sgpnt[i].address, sgpnt[i].length);
178 };
179 };
180 scsi_free(SCpnt->buffer, SCpnt->sglist_len);
181 if(SCpnt->request.sector % 4) this_count -= 2;
182
183 if(this_count > SCpnt->request.nr_sectors)
184 this_count -= 2;
185 };
186
187 #ifdef DEBUG
188 printk("(%x %x %x) ",SCpnt->request.bh, SCpnt->request.nr_sectors,
189 this_count);
190 #endif
191 if (SCpnt->request.nr_sectors > this_count)
192 {
193 SCpnt->request.errors = 0;
194 if (!SCpnt->request.bh)
195 panic("sr.c: linked page request (%lx %x)",
196 SCpnt->request.sector, this_count);
197 }
198
199 SCpnt = end_scsi_request(SCpnt, 1, this_count);
200 requeue_sr_request(SCpnt);
201 return;
202 }
203
204
205
206
207 if (SCpnt->use_sg) {
208 struct scatterlist * sgpnt;
209 int i;
210 sgpnt = (struct scatterlist *) SCpnt->buffer;
211 for(i=0; i<SCpnt->use_sg; i++) {
212 if (sgpnt[i].alt_address) {
213 scsi_free(sgpnt[i].address, sgpnt[i].length);
214 };
215 };
216 scsi_free(SCpnt->buffer, SCpnt->sglist_len);
217 } else {
218 if (SCpnt->buffer != SCpnt->request.buffer)
219 scsi_free(SCpnt->buffer, SCpnt->bufflen);
220 };
221
222 if (driver_byte(result) != 0) {
223 if ((SCpnt->sense_buffer[0] & 0x7f) == 0x70) {
224 if ((SCpnt->sense_buffer[2] & 0xf) == UNIT_ATTENTION) {
225
226
227
228 scsi_CDs[DEVICE_NR(SCpnt->request.dev)].device->changed = 1;
229 SCpnt = end_scsi_request(SCpnt, 0, this_count);
230 requeue_sr_request(SCpnt);
231 return;
232 }
233 }
234
235 if (SCpnt->sense_buffer[2] == ILLEGAL_REQUEST) {
236 printk("CD-ROM error: Drive reports ILLEGAL REQUEST.\n");
237 if (scsi_CDs[DEVICE_NR(SCpnt->request.dev)].ten) {
238 scsi_CDs[DEVICE_NR(SCpnt->request.dev)].ten = 0;
239 requeue_sr_request(SCpnt);
240 result = 0;
241 return;
242 } else {
243 printk("CD-ROM error: Drive reports %d.\n", SCpnt->sense_buffer[2]);
244 SCpnt = end_scsi_request(SCpnt, 0, this_count);
245 requeue_sr_request(SCpnt);
246 return;
247 }
248
249 }
250
251 if (SCpnt->sense_buffer[2] == NOT_READY) {
252 printk("CDROM not ready. Make sure you have a disc in the drive.\n");
253 SCpnt = end_scsi_request(SCpnt, 0, this_count);
254 requeue_sr_request(SCpnt);
255 return;
256 };
257 }
258
259
260 if(result) {
261 printk("SCSI CD error : host %d id %d lun %d return code = %03x\n",
262 scsi_CDs[DEVICE_NR(SCpnt->request.dev)].device->host->host_no,
263 scsi_CDs[DEVICE_NR(SCpnt->request.dev)].device->id,
264 scsi_CDs[DEVICE_NR(SCpnt->request.dev)].device->lun,
265 result);
266
267 if (status_byte(result) == CHECK_CONDITION)
268 print_sense("sr", SCpnt);
269
270 SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.current_nr_sectors);
271 requeue_sr_request(SCpnt);
272 }
273 }
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293 static void sr_photocd_done(Scsi_Cmnd *SCpnt)
294 {
295 SCpnt->request.dev = 0xfffe;
296 }
297
298 static void sr_photocd(struct inode *inode)
299 {
300 unsigned long sector,min,sec,frame;
301 Scsi_Cmnd *SCpnt;
302 unsigned char scsi_cmd[10];
303 unsigned char *buffer;
304 int rc;
305
306 switch(scsi_CDs[MINOR(inode->i_rdev)].device->manufacturer) {
307
308 case SCSI_MAN_NEC:
309 printk("sr_photocd: use NEC code\n");
310 SCpnt = allocate_device(NULL, scsi_CDs[MINOR(inode->i_rdev)].device,1);
311 memset(scsi_cmd,0,10);
312 scsi_cmd[0] = 0xde;
313 scsi_cmd[1] = ((scsi_CDs[MINOR(inode->i_rdev)].device->lun) << 5) | 0x03;
314 scsi_cmd[2] = 0xb0;
315 buffer = (unsigned char*) scsi_malloc(512);
316 scsi_do_cmd(SCpnt, scsi_cmd, buffer, 0x16,
317 sr_photocd_done, SR_TIMEOUT, MAX_RETRIES);
318 while (SCpnt->request.dev != 0xfffe);
319 rc = SCpnt->result;
320 if (driver_byte(rc) != 0) {
321 printk("sr_photocd: oops, CD-ROM reports an error.\n");
322 sector = 0; }
323 else {
324 min = (unsigned long)buffer[15]/16*10 + (unsigned long)buffer[15]%16;
325 sec = (unsigned long)buffer[16]/16*10 + (unsigned long)buffer[16]%16;
326 frame = (unsigned long)buffer[17]/16*10 + (unsigned long)buffer[17]%16;
327 sector = min*60*75 + sec*75 + frame;
328 if (sector) {
329 sector -= CD_BLOCK_OFFSET;
330 printk("sr_photocd: multisession PhotoCD detected\n");
331 }
332 }
333 scsi_free(buffer,512);
334 SCpnt->request.dev = -1;
335 break;
336
337 case SCSI_MAN_TOSHIBA:
338 printk("sr_photocd: use TOSHIBA code\n");
339
340
341 SCpnt = allocate_device(NULL, scsi_CDs[MINOR(inode->i_rdev)].device,1);
342 memset(scsi_cmd,0,10);
343 scsi_cmd[0] = 0x15;
344 scsi_cmd[1] = ((scsi_CDs[MINOR(inode->i_rdev)].device->lun) << 5)|(1 << 4);
345 scsi_cmd[4] = 12;
346 buffer = (unsigned char*) scsi_malloc(512);
347 memset(buffer,0,512);
348 buffer[ 3] = 0x08;
349 buffer[ 4] = 0x83;
350 buffer[10] = 0x08;
351 scsi_do_cmd(SCpnt, scsi_cmd, buffer, 12,
352 sr_photocd_done, SR_TIMEOUT, MAX_RETRIES);
353 while (SCpnt->request.dev != 0xfffe);
354 rc = SCpnt->result;
355 if (driver_byte(rc) != 0) {
356 printk("sr_photocd: oops, CD-ROM reports an error.\n"); }
357 scsi_free(buffer,512);
358 SCpnt->request.dev = -1;
359
360
361 SCpnt = allocate_device(NULL, scsi_CDs[MINOR(inode->i_rdev)].device,1);
362 memset(scsi_cmd,0,10);
363 scsi_cmd[0] = 0xc7;
364 scsi_cmd[1] = ((scsi_CDs[MINOR(inode->i_rdev)].device->lun) << 5) | 3;
365 buffer = (unsigned char*) scsi_malloc(512);
366 memset(buffer,0,512);
367 scsi_do_cmd(SCpnt, scsi_cmd, buffer, 4,
368 sr_photocd_done, SR_TIMEOUT, MAX_RETRIES);
369 while (SCpnt->request.dev != 0xfffe);
370 rc = SCpnt->result;
371 if (driver_byte(rc) != 0) {
372 printk("sr_photocd: oops, CD-ROM reports an error.\n");
373 sector = 0; }
374 else {
375 min = (unsigned long)buffer[1]/16*10 + (unsigned long)buffer[1]%16;
376 sec = (unsigned long)buffer[2]/16*10 + (unsigned long)buffer[2]%16;
377 frame = (unsigned long)buffer[3]/16*10 + (unsigned long)buffer[3]%16;
378 sector = min*60*75 + sec*75 + frame;
379 if (sector) {
380 sector -= CD_BLOCK_OFFSET;
381 printk("sr_photocd: multisession PhotoCD detected: %lu\n",sector);
382 }
383 }
384 scsi_free(buffer,512);
385 SCpnt->request.dev = -1;
386 break;
387 case SCSI_MAN_UNKNOWN:
388 default:
389 printk("sr_photocd: there is no special photocd-code for this drive\n");
390 sector = 0;
391 break; }
392
393 scsi_CDs[MINOR(inode->i_rdev)].mpcd_sector = sector;
394 return;
395 }
396
397 static int sr_open(struct inode * inode, struct file * filp)
398 {
399 if(MINOR(inode->i_rdev) >= sr_template.nr_dev ||
400 !scsi_CDs[MINOR(inode->i_rdev)].device) return -ENXIO;
401
402 if (filp->f_mode & 2)
403 return -EROFS;
404
405 check_disk_change(inode->i_rdev);
406
407 if(!scsi_CDs[MINOR(inode->i_rdev)].device->access_count++)
408 sr_ioctl(inode, NULL, SCSI_IOCTL_DOORLOCK, 0);
409
410
411
412
413
414
415 if(scsi_CDs[MINOR(inode->i_rdev)].needs_sector_size)
416 get_sectorsize(MINOR(inode->i_rdev));
417
418 #if 0
419 sr_photocd(inode);
420 #endif
421
422 return 0;
423 }
424
425
426
427
428
429
430
431 static void do_sr_request (void)
432 {
433 Scsi_Cmnd * SCpnt = NULL;
434 struct request * req = NULL;
435 int flag = 0;
436
437 while (1==1){
438 cli();
439 if (CURRENT != NULL && CURRENT->dev == -1) {
440 sti();
441 return;
442 };
443
444 INIT_SCSI_REQUEST;
445
446 if (flag++ == 0)
447 SCpnt = allocate_device(&CURRENT,
448 scsi_CDs[DEVICE_NR(MINOR(CURRENT->dev))].device, 0);
449 else SCpnt = NULL;
450 sti();
451
452
453
454
455
456
457
458
459 if (!SCpnt && sr_template.nr_dev > 1){
460 struct request *req1;
461 req1 = NULL;
462 cli();
463 req = CURRENT;
464 while(req){
465 SCpnt = request_queueable(req,
466 scsi_CDs[DEVICE_NR(MINOR(req->dev))].device);
467 if(SCpnt) break;
468 req1 = req;
469 req = req->next;
470 };
471 if (SCpnt && req->dev == -1) {
472 if (req == CURRENT)
473 CURRENT = CURRENT->next;
474 else
475 req1->next = req->next;
476 };
477 sti();
478 };
479
480 if (!SCpnt)
481 return;
482
483 wake_up(&wait_for_request);
484
485
486 requeue_sr_request(SCpnt);
487 };
488 }
489
490 void requeue_sr_request (Scsi_Cmnd * SCpnt)
491 {
492 unsigned int dev, block, realcount;
493 unsigned char cmd[10], *buffer, tries;
494 int this_count, start, end_rec;
495
496 tries = 2;
497
498 repeat:
499 if(!SCpnt || SCpnt->request.dev <= 0) {
500 do_sr_request();
501 return;
502 }
503
504 dev = MINOR(SCpnt->request.dev);
505 block = SCpnt->request.sector;
506 buffer = NULL;
507 this_count = 0;
508
509 if (dev >= sr_template.nr_dev)
510 {
511
512 SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
513 tries = 2;
514 goto repeat;
515 }
516
517 if (!scsi_CDs[dev].use)
518 {
519
520 SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
521 tries = 2;
522 goto repeat;
523 }
524
525 if (scsi_CDs[dev].device->changed)
526 {
527
528
529
530
531 SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
532 tries = 2;
533 goto repeat;
534 }
535
536 switch (SCpnt->request.cmd)
537 {
538 case WRITE:
539 SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
540 goto repeat;
541 break;
542 case READ :
543 cmd[0] = READ_6;
544 break;
545 default :
546 panic ("Unknown sr command %d\n", SCpnt->request.cmd);
547 }
548
549 cmd[1] = (SCpnt->lun << 5) & 0xe0;
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568 if (block >= 64 && block < 68) {
569 block += scsi_CDs[dev].mpcd_sector*4; }
570
571 SCpnt->use_sg = 0;
572
573 if (SCpnt->host->sg_tablesize > 0 &&
574 (!need_isa_buffer ||
575 dma_free_sectors >= 10)) {
576 struct buffer_head * bh;
577 struct scatterlist * sgpnt;
578 int count, this_count_max;
579 bh = SCpnt->request.bh;
580 this_count = 0;
581 count = 0;
582 this_count_max = (scsi_CDs[dev].ten ? 0xffff : 0xff) << 4;
583
584
585 this_count = SCpnt->request.sector % 4;
586 if(this_count) count++;
587 while(bh && count < SCpnt->host->sg_tablesize) {
588 if ((this_count + (bh->b_size >> 9)) > this_count_max) break;
589 this_count += (bh->b_size >> 9);
590 count++;
591 bh = bh->b_reqnext;
592 };
593
594 end_rec = 0;
595 if(this_count % 4) {
596 if (count < SCpnt->host->sg_tablesize) {
597 count++;
598 end_rec = (4 - (this_count % 4)) << 9;
599 this_count += 4 - (this_count % 4);
600 } else {
601 count--;
602 this_count -= (this_count % 4);
603 };
604 };
605 SCpnt->use_sg = count;
606 count = 512;
607 while( count < (SCpnt->use_sg * sizeof(struct scatterlist)))
608 count = count << 1;
609 SCpnt->sglist_len = count;
610 sgpnt = (struct scatterlist * ) scsi_malloc(count);
611 if (!sgpnt) {
612 printk("Warning - running *really* short on DMA buffers\n");
613 SCpnt->use_sg = 0;
614 } else {
615 buffer = (unsigned char *) sgpnt;
616 count = 0;
617 bh = SCpnt->request.bh;
618 if(SCpnt->request.sector % 4) {
619 sgpnt[count].length = (SCpnt->request.sector % 4) << 9;
620 sgpnt[count].address = (char *) scsi_malloc(sgpnt[count].length);
621 if(!sgpnt[count].address) panic("SCSI DMA pool exhausted.");
622 sgpnt[count].alt_address = sgpnt[count].address;
623
624 count++;
625 };
626 for(bh = SCpnt->request.bh; count < SCpnt->use_sg;
627 count++, bh = bh->b_reqnext) {
628 if (bh) {
629 sgpnt[count].address = bh->b_data;
630 sgpnt[count].length = bh->b_size;
631 sgpnt[count].alt_address = NULL;
632 } else {
633 sgpnt[count].address = (char *) scsi_malloc(end_rec);
634 if(!sgpnt[count].address) panic("SCSI DMA pool exhausted.");
635 sgpnt[count].length = end_rec;
636 sgpnt[count].alt_address = sgpnt[count].address;
637 if (count+1 != SCpnt->use_sg) panic("Bad sr request list");
638 break;
639 };
640 if (((int) sgpnt[count].address) + sgpnt[count].length >
641 ISA_DMA_THRESHOLD & (SCpnt->host->unchecked_isa_dma)) {
642 sgpnt[count].alt_address = sgpnt[count].address;
643
644
645
646 if(dma_free_sectors < (sgpnt[count].length >> 9) + 5) {
647 sgpnt[count].address = NULL;
648 } else {
649 sgpnt[count].address = (char *) scsi_malloc(sgpnt[count].length);
650 };
651
652
653
654
655 if(sgpnt[count].address == NULL){
656 printk("Warning: Running low on SCSI DMA buffers");
657
658 while(--count >= 0){
659 if(sgpnt[count].alt_address)
660 scsi_free(sgpnt[count].address, sgpnt[count].length);
661 };
662 SCpnt->use_sg = 0;
663 scsi_free(buffer, SCpnt->sglist_len);
664 break;
665 };
666 };
667 };
668 #ifdef DEBUG
669 printk("SG: %d %d %d %d %d *** ",SCpnt->use_sg, SCpnt->request.sector,
670 this_count,
671 SCpnt->request.current_nr_sectors,
672 SCpnt->request.nr_sectors);
673 for(count=0; count<SCpnt->use_sg; count++)
674 printk("SGlist: %d %x %x %x\n", count,
675 sgpnt[count].address,
676 sgpnt[count].alt_address,
677 sgpnt[count].length);
678 #endif
679 };
680 };
681
682 if (SCpnt->use_sg == 0){
683
684 if (!SCpnt->request.bh)
685 this_count = SCpnt->request.nr_sectors;
686 else
687 this_count = (SCpnt->request.bh->b_size >> 9);
688
689 start = block % 4;
690 if (start)
691 {
692 this_count = ((this_count > 4 - start) ?
693 (4 - start) : (this_count));
694 buffer = (unsigned char *) scsi_malloc(2048);
695 }
696 else if (this_count < 4)
697 {
698 buffer = (unsigned char *) scsi_malloc(2048);
699 }
700 else
701 {
702 this_count -= this_count % 4;
703 buffer = (unsigned char *) SCpnt->request.buffer;
704 if (((int) buffer) + (this_count << 9) > ISA_DMA_THRESHOLD &
705 (SCpnt->host->unchecked_isa_dma))
706 buffer = (unsigned char *) scsi_malloc(this_count << 9);
707 }
708 };
709
710 if (scsi_CDs[dev].sector_size == 2048)
711 block = block >> 2;
712 else
713 block = block & 0xfffffffc;
714
715 realcount = (this_count + 3) / 4;
716
717 if (scsi_CDs[dev].sector_size == 512) realcount = realcount << 2;
718
719 if (((realcount > 0xff) || (block > 0x1fffff)) && scsi_CDs[dev].ten)
720 {
721 if (realcount > 0xffff)
722 {
723 realcount = 0xffff;
724 this_count = realcount * (scsi_CDs[dev].sector_size >> 9);
725 }
726
727 cmd[0] += READ_10 - READ_6 ;
728 cmd[2] = (unsigned char) (block >> 24) & 0xff;
729 cmd[3] = (unsigned char) (block >> 16) & 0xff;
730 cmd[4] = (unsigned char) (block >> 8) & 0xff;
731 cmd[5] = (unsigned char) block & 0xff;
732 cmd[6] = cmd[9] = 0;
733 cmd[7] = (unsigned char) (realcount >> 8) & 0xff;
734 cmd[8] = (unsigned char) realcount & 0xff;
735 }
736 else
737 {
738 if (realcount > 0xff)
739 {
740 realcount = 0xff;
741 this_count = realcount * (scsi_CDs[dev].sector_size >> 9);
742 }
743
744 cmd[1] |= (unsigned char) ((block >> 16) & 0x1f);
745 cmd[2] = (unsigned char) ((block >> 8) & 0xff);
746 cmd[3] = (unsigned char) block & 0xff;
747 cmd[4] = (unsigned char) realcount;
748 cmd[5] = 0;
749 }
750
751 #ifdef DEBUG
752 {
753 int i;
754 printk("ReadCD: %d %d %d %d\n",block, realcount, buffer, this_count);
755 printk("Use sg: %d\n", SCpnt->use_sg);
756 printk("Dumping command: ");
757 for(i=0; i<12; i++) printk("%2.2x ", cmd[i]);
758 printk("\n");
759 };
760 #endif
761
762
763
764
765
766
767
768
769
770
771
772 SCpnt->transfersize = (scsi_CDs[dev].sector_size > 1024) ?
773 1024 : scsi_CDs[dev].sector_size;
774
775 SCpnt->this_count = this_count;
776 scsi_do_cmd (SCpnt, (void *) cmd, buffer,
777 realcount * scsi_CDs[dev].sector_size,
778 rw_intr, SR_TIMEOUT, MAX_RETRIES);
779 }
780
781 static int sr_detect(Scsi_Device * SDp){
782
783
784 if(scsi_loadable_module_flag) return 0;
785 if(SDp->type != TYPE_ROM && SDp->type != TYPE_WORM) return 0;
786
787 printk("Detected scsi CD-ROM sr%d at scsi%d, id %d, lun %d\n",
788 sr_template.dev_noticed++,
789 SDp->host->host_no , SDp->id, SDp->lun);
790
791 return 1;
792 }
793
794 static void sr_attach(Scsi_Device * SDp){
795 Scsi_CD * cpnt;
796 int i;
797
798
799
800 if(scsi_loadable_module_flag) return;
801 if(SDp->type != TYPE_ROM && SDp->type != TYPE_WORM) return;
802
803 if (sr_template.nr_dev >= sr_template.dev_max)
804 panic ("scsi_devices corrupt (sr)");
805
806 for(cpnt = scsi_CDs, i=0; i<sr_template.dev_max; i++, cpnt++)
807 if(!cpnt->device) break;
808
809 if(i >= sr_template.dev_max) panic ("scsi_devices corrupt (sr)");
810
811 SDp->scsi_request_fn = do_sr_request;
812 scsi_CDs[i].device = SDp;
813 sr_template.nr_dev++;
814 if(sr_template.nr_dev > sr_template.dev_max)
815 panic ("scsi_devices corrupt (sr)");
816 }
817
818
819 static void sr_init_done (Scsi_Cmnd * SCpnt)
820 {
821 struct request * req;
822
823 req = &SCpnt->request;
824 req->dev = 0xfffe;
825
826 if (req->sem != NULL) {
827 up(req->sem);
828 }
829 }
830
831 static void get_sectorsize(int i){
832 unsigned char cmd[10];
833 unsigned char *buffer;
834 int the_result, retries;
835 Scsi_Cmnd * SCpnt;
836
837 buffer = (unsigned char *) scsi_malloc(512);
838 SCpnt = allocate_device(NULL, scsi_CDs[i].device, 1);
839
840 retries = 3;
841 do {
842 cmd[0] = READ_CAPACITY;
843 cmd[1] = (scsi_CDs[i].device->lun << 5) & 0xe0;
844 memset ((void *) &cmd[2], 0, 8);
845 SCpnt->request.dev = 0xffff;
846 SCpnt->cmd_len = 0;
847
848 memset(buffer, 0, 8);
849
850 scsi_do_cmd (SCpnt,
851 (void *) cmd, (void *) buffer,
852 512, sr_init_done, SR_TIMEOUT,
853 MAX_RETRIES);
854
855 if (current == task[0])
856 while(SCpnt->request.dev != 0xfffe);
857 else
858 if (SCpnt->request.dev != 0xfffe){
859 struct semaphore sem = MUTEX_LOCKED;
860 SCpnt->request.sem = &sem;
861 down(&sem);
862
863 while (SCpnt->request.dev != 0xfffe) schedule();
864 };
865
866 the_result = SCpnt->result;
867 retries--;
868
869 } while(the_result && retries);
870
871 SCpnt->request.dev = -1;
872
873 wake_up(&SCpnt->device->device_wait);
874
875 if (the_result) {
876 scsi_CDs[i].capacity = 0x1fffff;
877 scsi_CDs[i].sector_size = 2048;
878 scsi_CDs[i].needs_sector_size = 1;
879 } else {
880 scsi_CDs[i].capacity = (buffer[0] << 24) |
881 (buffer[1] << 16) | (buffer[2] << 8) | buffer[3];
882 scsi_CDs[i].sector_size = (buffer[4] << 24) |
883 (buffer[5] << 16) | (buffer[6] << 8) | buffer[7];
884 if(scsi_CDs[i].sector_size == 0) scsi_CDs[i].sector_size = 2048;
885 if(scsi_CDs[i].sector_size != 2048 &&
886 scsi_CDs[i].sector_size != 512) {
887 printk ("scd%d : unsupported sector size %d.\n",
888 i, scsi_CDs[i].sector_size);
889 scsi_CDs[i].capacity = 0;
890 scsi_CDs[i].needs_sector_size = 1;
891 };
892 if(scsi_CDs[i].sector_size == 2048)
893 scsi_CDs[i].capacity *= 4;
894 scsi_CDs[i].needs_sector_size = 0;
895 };
896 scsi_free(buffer, 512);
897 }
898
899 static void sr_init()
900 {
901 int i;
902 static int sr_registered = 0;
903
904 if(sr_template.dev_noticed == 0) return;
905
906 if(!sr_registered) {
907 if (register_blkdev(MAJOR_NR,"sr",&sr_fops)) {
908 printk("Unable to get major %d for SCSI-CD\n",MAJOR_NR);
909 return;
910 }
911 }
912
913
914 if(scsi_loadable_module_flag) return;
915
916 sr_template.dev_max = sr_template.dev_noticed;
917 scsi_CDs = (Scsi_CD *) scsi_init_malloc(sr_template.dev_max * sizeof(Scsi_CD));
918 memset(scsi_CDs, 0, sr_template.dev_max * sizeof(Scsi_CD));
919
920 sr_sizes = (int *) scsi_init_malloc(sr_template.dev_max * sizeof(int));
921 memset(sr_sizes, 0, sr_template.dev_max * sizeof(int));
922
923 sr_blocksizes = (int *) scsi_init_malloc(sr_template.dev_max *
924 sizeof(int));
925 for(i=0;i<sr_template.dev_max;i++) sr_blocksizes[i] = 2048;
926 blksize_size[MAJOR_NR] = sr_blocksizes;
927
928 }
929
930 void sr_finish()
931 {
932 int i;
933
934 for (i = 0; i < sr_template.nr_dev; ++i)
935 {
936 get_sectorsize(i);
937 printk("Scd sectorsize = %d bytes\n", scsi_CDs[i].sector_size);
938 scsi_CDs[i].use = 1;
939 scsi_CDs[i].ten = 1;
940 scsi_CDs[i].remap = 1;
941 sr_sizes[i] = scsi_CDs[i].capacity;
942 }
943
944 blk_dev[MAJOR_NR].request_fn = DEVICE_REQUEST;
945 blk_size[MAJOR_NR] = sr_sizes;
946
947
948
949
950 if(scsi_CDs[0].device->host->sg_tablesize)
951 read_ahead[MAJOR_NR] = 32;
952 else
953 read_ahead[MAJOR_NR] = 4;
954
955 return;
956 }