root/drivers/scsi/sd.c

/* [previous][next][first][last][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. sd_open
  2. sd_release
  3. sd_geninit
  4. rw_intr
  5. do_sd_request
  6. requeue_sd_request
  7. check_scsidisk_media_change
  8. sd_init_done
  9. sd_init_onedisk
  10. sd_init
  11. sd_finish
  12. sd_detect
  13. sd_attach
  14. revalidate_scsidisk
  15. fop_revalidate_scsidisk
  16. sd_detach
  17. init_module
  18. cleanup_module

   1 /*
   2  *      sd.c Copyright (C) 1992 Drew Eckhardt 
   3  *           Copyright (C) 1993, 1994, 1995 Eric Youngdale
   4  *
   5  *      Linux scsi disk driver
   6  *              Initial versions: Drew Eckhardt 
   7  *              Subsequent revisions: Eric Youngdale
   8  *
   9  *      <drew@colorado.edu>
  10  *
  11  *       Modified by Eric Youngdale ericy@cais.com to
  12  *       add scatter-gather, multiple outstanding request, and other
  13  *       enhancements.
  14  *
  15  *       Modified by Eric Youngdale eric@aib.com to support loadable
  16  *       low-level scsi drivers.
  17  */
  18 
  19 #ifdef MODULE
  20 #include <linux/autoconf.h>
  21 #include <linux/module.h>
  22 #include <linux/version.h>
  23 /*
  24  * This is a variable in scsi.c that is set when we are processing something
  25  * after boot time.  By definition, this is true when we are a loadable module
  26  * ourselves.
  27  */
  28 #define MODULE_FLAG 1
  29 #else
  30 #define MODULE_FLAG scsi_loadable_module_flag
  31 #endif /* MODULE */
  32 
  33 #include <linux/fs.h>
  34 #include <linux/kernel.h>
  35 #include <linux/sched.h>
  36 #include <linux/mm.h>
  37 #include <linux/string.h>
  38 #include <linux/errno.h>
  39 #include <asm/system.h>
  40 
  41 #define MAJOR_NR SCSI_DISK_MAJOR
  42 #include "../block/blk.h"
  43 #include "scsi.h"
  44 #include "hosts.h"
  45 #include "sd.h"
  46 #include "scsi_ioctl.h"
  47 #include "constants.h"
  48 
  49 #include <linux/genhd.h>
  50 
  51 /*
  52  *  static const char RCSid[] = "$Header:";
  53  */
  54 
  55 #define MAX_RETRIES 5
  56 
  57 /*
  58  *  Time out in seconds for disks and Magneto-opticals (which are slower).
  59  */
  60 
  61 #define SD_TIMEOUT 700
  62 #define SD_MOD_TIMEOUT 750
  63 
  64 #define CLUSTERABLE_DEVICE(SC) (SC->host->use_clustering && \
  65                                 SC->device->type != TYPE_MOD)
  66 
  67 struct hd_struct * sd;
  68 int revalidate_scsidisk(int dev, int maxusage);
  69 
  70 Scsi_Disk * rscsi_disks = NULL;
  71 static int * sd_sizes;
  72 static int * sd_blocksizes;
  73 static int * sd_hardsizes;              /* Hardware sector size */
  74 
  75 extern int sd_ioctl(struct inode *, struct file *, unsigned int, unsigned long);
  76 
  77 static int check_scsidisk_media_change(dev_t);
  78 static int fop_revalidate_scsidisk(dev_t);
  79 
  80 static sd_init_onedisk(int);
  81 
  82 static void requeue_sd_request (Scsi_Cmnd * SCpnt);
  83 
  84 static void sd_init(void);
  85 static void sd_finish(void);
  86 static int sd_attach(Scsi_Device *);
  87 static int sd_detect(Scsi_Device *);
  88 static void sd_detach(Scsi_Device *);
  89 
  90 struct Scsi_Device_Template sd_template = 
  91 { NULL, "disk", "sd", NULL, TYPE_DISK, 
  92       SCSI_DISK_MAJOR, 0, 0, 0, 1,
  93       sd_detect, sd_init,
  94       sd_finish, sd_attach, sd_detach
  95 };
  96 
  97 static int sd_open(struct inode * inode, struct file * filp)
     /* [previous][next][first][last][top][bottom][index][help] */
  98 {
  99     int target;
 100     target =  DEVICE_NR(MINOR(inode->i_rdev));
 101     
 102     if(target >= sd_template.dev_max || !rscsi_disks[target].device)
 103         return -ENXIO;   /* No such device */
 104     
 105     /* 
 106      * Make sure that only one process can do a check_change_disk at one time.
 107      * This is also used to lock out further access when the partition table 
 108      * is being re-read. 
 109      */
 110     
 111     while (rscsi_disks[target].device->busy)
 112     barrier();   
 113     if(rscsi_disks[target].device->removable) {
 114         check_disk_change(inode->i_rdev);
 115         
 116         if(!rscsi_disks[target].device->access_count)
 117             sd_ioctl(inode, NULL, SCSI_IOCTL_DOORLOCK, 0);
 118     };
 119 
 120     /*
 121      * See if we are requesting a non-existent partition.  Do this
 122      * after checking for disk change.
 123      */
 124     if(sd_sizes[MINOR(inode->i_rdev)] == 0)
 125         return -ENXIO;
 126     
 127     rscsi_disks[target].device->access_count++;
 128     if (rscsi_disks[target].device->host->hostt->usage_count)
 129         (*rscsi_disks[target].device->host->hostt->usage_count)++;
 130     if(sd_template.usage_count) (*sd_template.usage_count)++;
 131     return 0;
 132 }
 133 
 134 static void sd_release(struct inode * inode, struct file * file)
     /* [previous][next][first][last][top][bottom][index][help] */
 135 {
 136     int target;
 137     sync_dev(inode->i_rdev);
 138     
 139     target =  DEVICE_NR(MINOR(inode->i_rdev));
 140     
 141     rscsi_disks[target].device->access_count--;
 142     if (rscsi_disks[target].device->host->hostt->usage_count)
 143         (*rscsi_disks[target].device->host->hostt->usage_count)--;
 144     if(sd_template.usage_count) (*sd_template.usage_count)--;
 145     
 146     if(rscsi_disks[target].device->removable) {
 147         if(!rscsi_disks[target].device->access_count)
 148             sd_ioctl(inode, NULL, SCSI_IOCTL_DOORUNLOCK, 0);
 149     }
 150 }
 151 
 152 static void sd_geninit(void);
 153 
 154 static struct file_operations sd_fops = {
 155     NULL,                        /* lseek - default */
 156     block_read,                  /* read - general block-dev read */
 157     block_write,                 /* write - general block-dev write */
 158     NULL,                        /* readdir - bad */
 159     NULL,                        /* select */
 160     sd_ioctl,                    /* ioctl */
 161     NULL,                        /* mmap */
 162     sd_open,                     /* open code */
 163     sd_release,                  /* release */
 164     block_fsync,                 /* fsync */
 165     NULL,                        /* fasync */
 166     check_scsidisk_media_change, /* Disk change */
 167     fop_revalidate_scsidisk      /* revalidate */
 168 };
 169 
 170 static struct gendisk sd_gendisk = {
 171     MAJOR_NR,                    /* Major number */
 172     "sd",                        /* Major name */
 173     4,                           /* Bits to shift to get real from partition */
 174     1 << 4,                      /* Number of partitions per real */
 175     0,                           /* maximum number of real */
 176     sd_geninit,                  /* init function */
 177     NULL,                        /* hd struct */
 178     NULL,                        /* block sizes */
 179     0,                           /* number */
 180     NULL,                        /* internal */
 181     NULL                         /* next */
 182 };
 183 
 184 static void sd_geninit (void)
     /* [previous][next][first][last][top][bottom][index][help] */
 185 {
 186     int i;
 187     
 188     for (i = 0; i < sd_template.dev_max; ++i)
 189         if(rscsi_disks[i].device) 
 190             sd[i << 4].nr_sects = rscsi_disks[i].capacity;
 191 #if 0
 192     /* No longer needed - we keep track of this as we attach/detach */
 193     sd_gendisk.nr_real = sd_template.dev_max;
 194 #endif
 195 }
 196 
 197 /*
 198  * rw_intr is the interrupt routine for the device driver.  It will
 199  * be notified on the end of a SCSI read / write, and
 200  * will take on of several actions based on success or failure.
 201  */
 202 
 203 static void rw_intr (Scsi_Cmnd *SCpnt)
     /* [previous][next][first][last][top][bottom][index][help] */
 204 {
 205     int result = SCpnt->result;
 206     int this_count = SCpnt->bufflen >> 9;
 207     
 208 #ifdef DEBUG
 209     printk("sd%c : rw_intr(%d, %d)\n", 'a' + MINOR(SCpnt->request.dev), 
 210            SCpnt->host->host_no, result);
 211 #endif
 212     
 213     /*
 214      * First case : we assume that the command succeeded.  One of two things 
 215      * will happen here.  Either we will be finished, or there will be more
 216      * sectors that we were unable to read last time.
 217      */
 218 
 219     if (!result) {
 220         
 221 #ifdef DEBUG
 222         printk("sd%c : %d sectors remain.\n", 'a' + MINOR(SCpnt->request.dev),
 223                SCpnt->request.nr_sectors);
 224         printk("use_sg is %d\n ",SCpnt->use_sg);
 225 #endif
 226         if (SCpnt->use_sg) {
 227             struct scatterlist * sgpnt;
 228             int i;
 229             sgpnt = (struct scatterlist *) SCpnt->buffer;
 230             for(i=0; i<SCpnt->use_sg; i++) {
 231 #ifdef DEBUG
 232                 printk(":%x %x %d\n",sgpnt[i].alt_address, sgpnt[i].address, 
 233                        sgpnt[i].length);
 234 #endif
 235                 if (sgpnt[i].alt_address) {
 236                     if (SCpnt->request.cmd == READ)
 237                         memcpy(sgpnt[i].alt_address, sgpnt[i].address, 
 238                                sgpnt[i].length);
 239                     scsi_free(sgpnt[i].address, sgpnt[i].length);
 240                 };
 241             };
 242 
 243             /* Free list of scatter-gather pointers */
 244             scsi_free(SCpnt->buffer, SCpnt->sglist_len);  
 245         } else {
 246             if (SCpnt->buffer != SCpnt->request.buffer) {
 247 #ifdef DEBUG
 248                 printk("nosg: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer,
 249                        SCpnt->bufflen);
 250 #endif  
 251                 if (SCpnt->request.cmd == READ)
 252                     memcpy(SCpnt->request.buffer, SCpnt->buffer,
 253                            SCpnt->bufflen);
 254                 scsi_free(SCpnt->buffer, SCpnt->bufflen);
 255             };
 256         };
 257         /*
 258          * If multiple sectors are requested in one buffer, then
 259          * they will have been finished off by the first command.
 260          * If not, then we have a multi-buffer command.
 261          */
 262         if (SCpnt->request.nr_sectors > this_count)
 263         {
 264             SCpnt->request.errors = 0;
 265             
 266             if (!SCpnt->request.bh)
 267             {
 268 #ifdef DEBUG
 269                 printk("sd%c : handling page request, no buffer\n",
 270                        'a' + MINOR(SCpnt->request.dev));
 271 #endif
 272                 /*
 273                  * The SCpnt->request.nr_sectors field is always done in 
 274                  * 512 byte sectors, even if this really isn't the case.
 275                  */
 276                 panic("sd.c: linked page request (%lx %x)",
 277                       SCpnt->request.sector, this_count);
 278             }
 279         }
 280         SCpnt = end_scsi_request(SCpnt, 1, this_count);
 281         requeue_sd_request(SCpnt);
 282         return;
 283     }
 284     
 285     /* Free up any indirection buffers we allocated for DMA purposes. */
 286     if (SCpnt->use_sg) {
 287         struct scatterlist * sgpnt;
 288         int i;
 289         sgpnt = (struct scatterlist *) SCpnt->buffer;
 290         for(i=0; i<SCpnt->use_sg; i++) {
 291 #ifdef DEBUG
 292             printk("err: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer,
 293                    SCpnt->bufflen);
 294 #endif
 295             if (sgpnt[i].alt_address) {
 296                 scsi_free(sgpnt[i].address, sgpnt[i].length);
 297             };
 298         };
 299         scsi_free(SCpnt->buffer, SCpnt->sglist_len);  /* Free list of scatter-gather pointers */
 300     } else {
 301 #ifdef DEBUG
 302         printk("nosgerr: %x %x %d\n",SCpnt->request.buffer, SCpnt->buffer,
 303                SCpnt->bufflen);
 304 #endif
 305         if (SCpnt->buffer != SCpnt->request.buffer)
 306             scsi_free(SCpnt->buffer, SCpnt->bufflen);
 307     };
 308     
 309     /*
 310      * Now, if we were good little boys and girls, Santa left us a request
 311      * sense buffer.  We can extract information from this, so we
 312      * can choose a block to remap, etc.
 313      */
 314 
 315     if (driver_byte(result) != 0) {
 316         if (suggestion(result) == SUGGEST_REMAP) {
 317 #ifdef REMAP
 318             /*
 319              * Not yet implemented.  A read will fail after being remapped,
 320              * a write will call the strategy routine again.
 321              */
 322             if rscsi_disks[DEVICE_NR(SCpnt->request.dev)].remap
 323             {
 324                 result = 0;
 325             }
 326             else
 327 #endif
 328         }
 329         
 330         if ((SCpnt->sense_buffer[0] & 0x7f) == 0x70) {
 331             if ((SCpnt->sense_buffer[2] & 0xf) == UNIT_ATTENTION) {
 332                 if(rscsi_disks[DEVICE_NR(SCpnt->request.dev)].device->removable) {
 333                     /* detected disc change.  set a bit and quietly refuse
 334                      * further access.
 335                      */  
 336                     rscsi_disks[DEVICE_NR(SCpnt->request.dev)].device->changed = 1;
 337                     SCpnt = end_scsi_request(SCpnt, 0, this_count);
 338                     requeue_sd_request(SCpnt);
 339                     return;
 340                 }
 341             }
 342         }
 343         
 344         
 345         /* If we had an ILLEGAL REQUEST returned, then we may have
 346          * performed an unsupported command.  The only thing this should be 
 347          * would be a ten byte read where only a six byte read was supported.
 348          * Also, on a system where READ CAPACITY failed, we have have read 
 349          * past the end of the disk. 
 350          */
 351 
 352         if (SCpnt->sense_buffer[2] == ILLEGAL_REQUEST) {
 353             if (rscsi_disks[DEVICE_NR(SCpnt->request.dev)].ten) {
 354                 rscsi_disks[DEVICE_NR(SCpnt->request.dev)].ten = 0;
 355                 requeue_sd_request(SCpnt);
 356                 result = 0;
 357             } else {
 358                 /* ???? */
 359             }
 360         }
 361     }  /* driver byte != 0 */
 362     if (result) {
 363         printk("SCSI disk error : host %d channel %d id %d lun %d return code = %x\n",
 364                rscsi_disks[DEVICE_NR(SCpnt->request.dev)].device->host->host_no,
 365                rscsi_disks[DEVICE_NR(SCpnt->request.dev)].device->channel,
 366            rscsi_disks[DEVICE_NR(SCpnt->request.dev)].device->id,
 367              rscsi_disks[DEVICE_NR(SCpnt->request.dev)].device->lun, result);
 368         
 369         if (driver_byte(result) & DRIVER_SENSE)
 370             print_sense("sd", SCpnt);
 371         SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.current_nr_sectors);
 372         requeue_sd_request(SCpnt);
 373         return;
 374     }
 375 }
 376 
 377 /*
 378  * requeue_sd_request() is the request handler function for the sd driver.
 379  * Its function in life is to take block device requests, and translate
 380  * them to SCSI commands.
 381  */
 382 
 383 static void do_sd_request (void)
     /* [previous][next][first][last][top][bottom][index][help] */
 384 {
 385     Scsi_Cmnd * SCpnt = NULL;
 386     struct request * req = NULL;
 387     unsigned long flags;
 388     int flag = 0;
 389     
 390     save_flags(flags);
 391     while (1==1){
 392         cli();
 393         if (CURRENT != NULL && CURRENT->dev == -1) {
 394             restore_flags(flags);
 395             return;
 396         };
 397         
 398         INIT_SCSI_REQUEST;
 399                 
 400         /* We have to be careful here. allocate_device will get a free pointer,
 401          * but there is no guarantee that it is queueable.  In normal usage, 
 402          * we want to call this, because other types of devices may have the 
 403          * host all tied up, and we want to make sure that we have at least 
 404          * one request pending for this type of device. We can also come 
 405          * through here while servicing an interrupt, because of the need to 
 406          * start another command. If we call allocate_device more than once, 
 407          * then the system can wedge if the command is not queueable. The 
 408          * request_queueable function is safe because it checks to make sure 
 409          * that the host is able to take another command before it returns
 410          * a pointer.  
 411          */
 412 
 413         if (flag++ == 0)
 414             SCpnt = allocate_device(&CURRENT,
 415                                     rscsi_disks[DEVICE_NR(MINOR(CURRENT->dev))].device, 0); 
 416         else SCpnt = NULL;
 417         
 418         /*
 419          * The following restore_flags leads to latency problems.  FIXME.
 420          * Using a "sti()" gets rid of the latency problems but causes
 421          * race conditions and crashes.
 422          */
 423         restore_flags(flags);
 424 
 425         /* This is a performance enhancement. We dig down into the request 
 426          * list and try and find a queueable request (i.e. device not busy, 
 427          * and host able to accept another command. If we find one, then we 
 428          * queue it. This can make a big difference on systems with more than 
 429          * one disk drive.  We want to have the interrupts off when monkeying 
 430          * with the request list, because otherwise the kernel might try and 
 431          * slip in a request in between somewhere. 
 432          */
 433 
 434         if (!SCpnt && sd_template.nr_dev > 1){
 435             struct request *req1;
 436             req1 = NULL;
 437             cli();
 438             req = CURRENT;
 439             while(req){
 440                 SCpnt = request_queueable(req, rscsi_disks[DEVICE_NR(MINOR(req->dev))].device);
 441                 if(SCpnt) break;
 442                 req1 = req;
 443                 req = req->next;
 444             };
 445             if (SCpnt && req->dev == -1) {
 446                 if (req == CURRENT) 
 447                     CURRENT = CURRENT->next;
 448                 else
 449                     req1->next = req->next;
 450             };
 451             restore_flags(flags);
 452         };
 453         
 454         if (!SCpnt) return; /* Could not find anything to do */
 455         
 456         /* Queue command */
 457         requeue_sd_request(SCpnt);
 458     };  /* While */
 459 }    
 460 
 461 static void requeue_sd_request (Scsi_Cmnd * SCpnt)
     /* [previous][next][first][last][top][bottom][index][help] */
 462 {
 463     int dev, block, this_count;
 464     unsigned char cmd[10];
 465     int bounce_size, contiguous;
 466     int max_sg;
 467     struct buffer_head * bh, *bhp;
 468     char * buff, *bounce_buffer;
 469     
 470  repeat:
 471     
 472     if(!SCpnt || SCpnt->request.dev <= 0) {
 473         do_sd_request();
 474         return;
 475     }
 476     
 477     dev =  MINOR(SCpnt->request.dev);
 478     block = SCpnt->request.sector;
 479     this_count = 0;
 480 
 481 #ifdef DEBUG
 482     printk("Doing sd request, dev = %d, block = %d\n", dev, block);
 483 #endif
 484     
 485     if (dev >= (sd_template.dev_max << 4) || 
 486         !rscsi_disks[DEVICE_NR(dev)].device ||
 487         block + SCpnt->request.nr_sectors > sd[dev].nr_sects)
 488     {
 489         SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
 490         goto repeat;
 491     }
 492     
 493     block += sd[dev].start_sect;
 494     dev = DEVICE_NR(dev);
 495     
 496     if (rscsi_disks[dev].device->changed)
 497     {
 498         /*
 499          * quietly refuse to do anything to a changed disc until the changed 
 500          * bit has been reset
 501          */
 502         /* printk("SCSI disk has been changed. Prohibiting further I/O.\n"); */
 503         SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
 504         goto repeat;
 505     }
 506     
 507 #ifdef DEBUG
 508     printk("sd%c : real dev = /dev/sd%c, block = %d\n", 
 509            'a' + MINOR(SCpnt->request.dev), dev, block);
 510 #endif
 511     
 512     /*
 513      * If we have a 1K hardware sectorsize, prevent access to single
 514      * 512 byte sectors.  In theory we could handle this - in fact
 515      * the scsi cdrom driver must be able to handle this because
 516      * we typically use 1K blocksizes, and cdroms typically have
 517      * 2K hardware sectorsizes.  Of course, things are simpler
 518      * with the cdrom, since it is read-only.  For performance
 519      * reasons, the filesystems should be able to handle this
 520      * and not force the scsi disk driver to use bounce buffers
 521      * for this.
 522      */
 523     if (rscsi_disks[dev].sector_size == 1024)
 524         if((block & 1) || (SCpnt->request.nr_sectors & 1)) {
 525             printk("sd.c:Bad block number requested");
 526             SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
 527             goto repeat;
 528         }
 529     
 530     switch (SCpnt->request.cmd)
 531     {
 532     case WRITE :
 533         if (!rscsi_disks[dev].device->writeable)
 534         {
 535             SCpnt = end_scsi_request(SCpnt, 0, SCpnt->request.nr_sectors);
 536             goto repeat;
 537         }
 538         cmd[0] = WRITE_6;
 539         break;
 540     case READ :
 541         cmd[0] = READ_6;
 542         break;
 543     default :
 544         panic ("Unknown sd command %d\n", SCpnt->request.cmd);
 545     }
 546     
 547     SCpnt->this_count = 0;
 548     
 549     /* If the host adapter can deal with very large scatter-gather
 550      * requests, it is a waste of time to cluster 
 551      */
 552     contiguous = (!CLUSTERABLE_DEVICE(SCpnt) ? 0 :1);
 553     bounce_buffer = NULL;
 554     bounce_size = (SCpnt->request.nr_sectors << 9);
 555     
 556     /* First see if we need a bounce buffer for this request. If we do, make 
 557      * sure that we can allocate a buffer. Do not waste space by allocating 
 558      * a bounce buffer if we are straddling the 16Mb line 
 559      */ 
 560     if (contiguous && SCpnt->request.bh &&
 561         ((long) SCpnt->request.bh->b_data) 
 562         + (SCpnt->request.nr_sectors << 9) - 1 > ISA_DMA_THRESHOLD 
 563         && SCpnt->host->unchecked_isa_dma) {
 564         if(((long) SCpnt->request.bh->b_data) > ISA_DMA_THRESHOLD)
 565             bounce_buffer = (char *) scsi_malloc(bounce_size);
 566         if(!bounce_buffer) contiguous = 0;
 567     };
 568     
 569     if(contiguous && SCpnt->request.bh && SCpnt->request.bh->b_reqnext)
 570         for(bh = SCpnt->request.bh, bhp = bh->b_reqnext; bhp; bh = bhp, 
 571             bhp = bhp->b_reqnext) {
 572             if(!CONTIGUOUS_BUFFERS(bh,bhp)) { 
 573                 if(bounce_buffer) scsi_free(bounce_buffer, bounce_size);
 574                 contiguous = 0;
 575                 break;
 576             } 
 577         };
 578     if (!SCpnt->request.bh || contiguous) {
 579         
 580         /* case of page request (i.e. raw device), or unlinked buffer */
 581         this_count = SCpnt->request.nr_sectors;
 582         buff = SCpnt->request.buffer;
 583         SCpnt->use_sg = 0;
 584         
 585     } else if (SCpnt->host->sg_tablesize == 0 ||
 586                (need_isa_buffer && dma_free_sectors <= 10)) {
 587         
 588         /* Case of host adapter that cannot scatter-gather.  We also
 589          * come here if we are running low on DMA buffer memory.  We set
 590          * a threshold higher than that we would need for this request so
 591          * we leave room for other requests.  Even though we would not need
 592          * it all, we need to be conservative, because if we run low enough
 593          * we have no choice but to panic. 
 594          */
 595         if (SCpnt->host->sg_tablesize != 0 &&
 596             need_isa_buffer && 
 597             dma_free_sectors <= 10)
 598             printk("Warning: SCSI DMA buffer space running low.  Using non scatter-gather I/O.\n");
 599         
 600         this_count = SCpnt->request.current_nr_sectors;
 601         buff = SCpnt->request.buffer;
 602         SCpnt->use_sg = 0;
 603         
 604     } else {
 605         
 606         /* Scatter-gather capable host adapter */
 607         struct scatterlist * sgpnt;
 608         int count, this_count_max;
 609         int counted;
 610         
 611         bh = SCpnt->request.bh;
 612         this_count = 0;
 613         this_count_max = (rscsi_disks[dev].ten ? 0xffff : 0xff);
 614         count = 0;
 615         bhp = NULL;
 616         while(bh) {
 617             if ((this_count + (bh->b_size >> 9)) > this_count_max) break;
 618             if(!bhp || !CONTIGUOUS_BUFFERS(bhp,bh) ||
 619                !CLUSTERABLE_DEVICE(SCpnt) ||
 620                (SCpnt->host->unchecked_isa_dma &&
 621                 ((unsigned long) bh->b_data-1) == ISA_DMA_THRESHOLD)) {
 622                 if (count < SCpnt->host->sg_tablesize) count++;
 623                 else break;
 624             };
 625             this_count += (bh->b_size >> 9);
 626             bhp = bh;
 627             bh = bh->b_reqnext;
 628         };
 629 #if 0
 630         if(SCpnt->host->unchecked_isa_dma &&
 631            ((unsigned int) SCpnt->request.bh->b_data-1) == ISA_DMA_THRESHOLD) count--;
 632 #endif
 633         SCpnt->use_sg = count;  /* Number of chains */
 634         count = 512;/* scsi_malloc can only allocate in chunks of 512 bytes */
 635         while( count < (SCpnt->use_sg * sizeof(struct scatterlist))) 
 636             count = count << 1;
 637         SCpnt->sglist_len = count;
 638         max_sg = count / sizeof(struct scatterlist);
 639         if(SCpnt->host->sg_tablesize < max_sg) 
 640             max_sg = SCpnt->host->sg_tablesize;
 641         sgpnt = (struct scatterlist * ) scsi_malloc(count);
 642         if (!sgpnt) {
 643             printk("Warning - running *really* short on DMA buffers\n");
 644             SCpnt->use_sg = 0;    /* No memory left - bail out */
 645             this_count = SCpnt->request.current_nr_sectors;
 646             buff = SCpnt->request.buffer;
 647         } else {
 648             memset(sgpnt, 0, count);  /* Zero so it is easy to fill, but only
 649                                        * if memory is available 
 650                                        */
 651             buff = (char *) sgpnt;
 652             counted = 0;
 653             for(count = 0, bh = SCpnt->request.bh, bhp = bh->b_reqnext;
 654                 count < SCpnt->use_sg && bh; 
 655                 count++, bh = bhp) {
 656                 
 657                 bhp = bh->b_reqnext;
 658                 
 659                 if(!sgpnt[count].address) sgpnt[count].address = bh->b_data;
 660                 sgpnt[count].length += bh->b_size;
 661                 counted += bh->b_size >> 9;
 662                 
 663                 if (((long) sgpnt[count].address) + sgpnt[count].length - 1 > 
 664                     ISA_DMA_THRESHOLD && (SCpnt->host->unchecked_isa_dma) &&
 665                     !sgpnt[count].alt_address) {
 666                     sgpnt[count].alt_address = sgpnt[count].address;
 667                     /* We try and avoid exhausting the DMA pool, since it is 
 668                      * easier to control usage here. In other places we might 
 669                      * have a more pressing need, and we would be screwed if 
 670                      * we ran out */
 671                     if(dma_free_sectors < (sgpnt[count].length >> 9) + 10) {
 672                         sgpnt[count].address = NULL;
 673                     } else {
 674                         sgpnt[count].address = 
 675                             (char *) scsi_malloc(sgpnt[count].length);
 676                     };
 677                     /* If we start running low on DMA buffers, we abort the 
 678                      * scatter-gather operation, and free all of the memory 
 679                      * we have allocated.  We want to ensure that all scsi 
 680                      * operations are able to do at least a non-scatter/gather
 681                      * operation */
 682                     if(sgpnt[count].address == NULL){ /* Out of dma memory */
 683 #if 0
 684                         printk("Warning: Running low on SCSI DMA buffers");
 685                         /* Try switching back to a non s-g operation. */
 686                         while(--count >= 0){
 687                             if(sgpnt[count].alt_address) 
 688                                 scsi_free(sgpnt[count].address, 
 689                                           sgpnt[count].length);
 690                         };
 691                         this_count = SCpnt->request.current_nr_sectors;
 692                         buff = SCpnt->request.buffer;
 693                         SCpnt->use_sg = 0;
 694                         scsi_free(sgpnt, SCpnt->sglist_len);
 695 #endif
 696                         SCpnt->use_sg = count;
 697                         this_count = counted -= bh->b_size >> 9;
 698                         break;
 699                     };
 700                     
 701                 };
 702                 
 703                 /* Only cluster buffers if we know that we can supply DMA 
 704                  * buffers large enough to satisfy the request. Do not cluster
 705                  * a new request if this would mean that we suddenly need to 
 706                  * start using DMA bounce buffers */
 707                 if(bhp && CONTIGUOUS_BUFFERS(bh,bhp) 
 708                    && CLUSTERABLE_DEVICE(SCpnt)) {
 709                     char * tmp;
 710                     
 711                     if (((long) sgpnt[count].address) + sgpnt[count].length +
 712                         bhp->b_size - 1 > ISA_DMA_THRESHOLD && 
 713                         (SCpnt->host->unchecked_isa_dma) &&
 714                         !sgpnt[count].alt_address) continue;
 715                     
 716                     if(!sgpnt[count].alt_address) {count--; continue; }
 717                     if(dma_free_sectors > 10)
 718                         tmp = (char *) scsi_malloc(sgpnt[count].length 
 719                                                    + bhp->b_size);
 720                     else {
 721                         tmp = NULL;
 722                         max_sg = SCpnt->use_sg;
 723                     };
 724                     if(tmp){
 725                         scsi_free(sgpnt[count].address, sgpnt[count].length);
 726                         sgpnt[count].address = tmp;
 727                         count--;
 728                         continue;
 729                     };
 730                     
 731                     /* If we are allowed another sg chain, then increment 
 732                      * counter so we can insert it.  Otherwise we will end 
 733                      up truncating */
 734                     
 735                     if (SCpnt->use_sg < max_sg) SCpnt->use_sg++;
 736                 };  /* contiguous buffers */
 737             }; /* for loop */
 738             
 739             /* This is actually how many we are going to transfer */
 740             this_count = counted; 
 741             
 742             if(count < SCpnt->use_sg || SCpnt->use_sg 
 743                > SCpnt->host->sg_tablesize){
 744                 bh = SCpnt->request.bh;
 745                 printk("Use sg, count %d %x %d\n", 
 746                        SCpnt->use_sg, count, dma_free_sectors);
 747                 printk("maxsg = %x, counted = %d this_count = %d\n", 
 748                        max_sg, counted, this_count);
 749                 while(bh){
 750                     printk("[%p %lx] ", bh->b_data, bh->b_size);
 751                     bh = bh->b_reqnext;
 752                 };
 753                 if(SCpnt->use_sg < 16)
 754                     for(count=0; count<SCpnt->use_sg; count++)
 755                         printk("{%d:%p %p %d}  ", count,
 756                                sgpnt[count].address,
 757                                sgpnt[count].alt_address,
 758                                sgpnt[count].length);
 759                 panic("Ooops");
 760             };
 761             
 762             if (SCpnt->request.cmd == WRITE)
 763                 for(count=0; count<SCpnt->use_sg; count++)
 764                     if(sgpnt[count].alt_address)
 765                         memcpy(sgpnt[count].address, sgpnt[count].alt_address, 
 766                                sgpnt[count].length);
 767         };  /* Able to malloc sgpnt */
 768     };  /* Host adapter capable of scatter-gather */
 769     
 770     /* Now handle the possibility of DMA to addresses > 16Mb */
 771     
 772     if(SCpnt->use_sg == 0){
 773         if (((long) buff) + (this_count << 9) - 1 > ISA_DMA_THRESHOLD && 
 774             (SCpnt->host->unchecked_isa_dma)) {
 775             if(bounce_buffer)
 776                 buff = bounce_buffer;
 777             else
 778                 buff = (char *) scsi_malloc(this_count << 9);
 779             if(buff == NULL) {  /* Try backing off a bit if we are low on mem*/
 780                 this_count = SCpnt->request.current_nr_sectors;
 781                 buff = (char *) scsi_malloc(this_count << 9);
 782                 if(!buff) panic("Ran out of DMA buffers.");
 783             };
 784             if (SCpnt->request.cmd == WRITE)
 785                 memcpy(buff, (char *)SCpnt->request.buffer, this_count << 9);
 786         };
 787     };
 788 #ifdef DEBUG
 789     printk("sd%c : %s %d/%d 512 byte blocks.\n", 
 790            'a' + MINOR(SCpnt->request.dev),
 791            (SCpnt->request.cmd == WRITE) ? "writing" : "reading",
 792            this_count, SCpnt->request.nr_sectors);
 793 #endif
 794     
 795     cmd[1] = (SCpnt->lun << 5) & 0xe0;
 796     
 797     if (rscsi_disks[dev].sector_size == 1024){
 798         if(block & 1) panic("sd.c:Bad block number requested");
 799         if(this_count & 1) panic("sd.c:Bad block number requested");
 800         block = block >> 1;
 801         this_count = this_count >> 1;
 802     };
 803     
 804     if (rscsi_disks[dev].sector_size == 256){
 805         block = block << 1;
 806         this_count = this_count << 1;
 807     };
 808     
 809     if (((this_count > 0xff) ||  (block > 0x1fffff)) && rscsi_disks[dev].ten)
 810     {
 811         if (this_count > 0xffff)
 812             this_count = 0xffff;
 813         
 814         cmd[0] += READ_10 - READ_6 ;
 815         cmd[2] = (unsigned char) (block >> 24) & 0xff;
 816         cmd[3] = (unsigned char) (block >> 16) & 0xff;
 817         cmd[4] = (unsigned char) (block >> 8) & 0xff;
 818         cmd[5] = (unsigned char) block & 0xff;
 819         cmd[6] = cmd[9] = 0;
 820         cmd[7] = (unsigned char) (this_count >> 8) & 0xff;
 821         cmd[8] = (unsigned char) this_count & 0xff;
 822     }
 823     else
 824     {
 825         if (this_count > 0xff)
 826             this_count = 0xff;
 827         
 828         cmd[1] |= (unsigned char) ((block >> 16) & 0x1f);
 829         cmd[2] = (unsigned char) ((block >> 8) & 0xff);
 830         cmd[3] = (unsigned char) block & 0xff;
 831         cmd[4] = (unsigned char) this_count;
 832         cmd[5] = 0;
 833     }
 834     
 835     /*
 836      * We shouldn't disconnect in the middle of a sector, so with a dumb 
 837      * host adapter, it's safe to assume that we can at least transfer 
 838      * this many bytes between each connect / disconnect.  
 839      */
 840     
 841     SCpnt->transfersize = rscsi_disks[dev].sector_size;
 842     SCpnt->underflow = this_count << 9; 
 843     scsi_do_cmd (SCpnt, (void *) cmd, buff, 
 844                  this_count * rscsi_disks[dev].sector_size,
 845                  rw_intr, 
 846                  (SCpnt->device->type == TYPE_DISK ? 
 847                   SD_TIMEOUT : SD_MOD_TIMEOUT),
 848                  MAX_RETRIES);
 849 }
 850 
 851 static int check_scsidisk_media_change(dev_t full_dev){
     /* [previous][next][first][last][top][bottom][index][help] */
 852     int retval;
 853     int target;
 854     struct inode inode;
 855     int flag = 0;
 856     
 857     target =  DEVICE_NR(MINOR(full_dev));
 858     
 859     if (target >= sd_template.dev_max ||
 860         !rscsi_disks[target].device) {
 861         printk("SCSI disk request error: invalid device.\n");
 862         return 0;
 863     };
 864     
 865     if(!rscsi_disks[target].device->removable) return 0;
 866     
 867     inode.i_rdev = full_dev;  /* This is all we really need here */
 868     retval = sd_ioctl(&inode, NULL, SCSI_IOCTL_TEST_UNIT_READY, 0);
 869     
 870     if(retval){ /* Unable to test, unit probably not ready.  This usually
 871                  * means there is no disc in the drive.  Mark as changed,
 872                  * and we will figure it out later once the drive is
 873                  * available again.  */
 874         
 875         rscsi_disks[target].device->changed = 1;
 876         return 1; /* This will force a flush, if called from
 877                    * check_disk_change */
 878     };
 879     
 880     retval = rscsi_disks[target].device->changed;
 881     if(!flag) rscsi_disks[target].device->changed = 0;
 882     return retval;
 883 }
 884 
 885 static void sd_init_done (Scsi_Cmnd * SCpnt)
     /* [previous][next][first][last][top][bottom][index][help] */
 886 {
 887     struct request * req;
 888     
 889     req = &SCpnt->request;
 890     req->dev = 0xfffe; /* Busy, but indicate request done */
 891     
 892     if (req->sem != NULL) {
 893         up(req->sem);
 894     }
 895 }
 896 
 897 static int sd_init_onedisk(int i)
     /* [previous][next][first][last][top][bottom][index][help] */
 898 {
 899     unsigned char cmd[10];
 900     unsigned char *buffer;
 901     unsigned long spintime;
 902     int the_result, retries;
 903     Scsi_Cmnd * SCpnt;
 904     
 905     /* We need to retry the READ_CAPACITY because a UNIT_ATTENTION is 
 906      * considered a fatal error, and many devices report such an error 
 907      * just after a scsi bus reset. */
 908     
 909     SCpnt = allocate_device(NULL, rscsi_disks[i].device, 1);
 910     buffer = (unsigned char *) scsi_malloc(512);
 911     
 912     spintime = 0;
 913     
 914     /* Spin up drives, as required.  Only do this at boot time */
 915     if (current->pid == 0){
 916         do{
 917             retries = 0;
 918             while(retries < 3)
 919             {
 920                 cmd[0] = TEST_UNIT_READY;
 921                 cmd[1] = (rscsi_disks[i].device->lun << 5) & 0xe0;
 922                 memset ((void *) &cmd[2], 0, 8);
 923                 SCpnt->request.dev = 0xffff;  /* Mark as really busy again */
 924                 SCpnt->cmd_len = 0;
 925                 SCpnt->sense_buffer[0] = 0;
 926                 SCpnt->sense_buffer[2] = 0;
 927                 
 928                 scsi_do_cmd (SCpnt,
 929                              (void *) cmd, (void *) buffer,
 930                              512, sd_init_done,  SD_TIMEOUT,
 931                              MAX_RETRIES);
 932                 
 933                 while(SCpnt->request.dev != 0xfffe) barrier();
 934                 
 935                 the_result = SCpnt->result;
 936                 retries++;
 937                 if(   the_result == 0
 938                    || SCpnt->sense_buffer[2] != UNIT_ATTENTION)
 939                     break;
 940             }
 941             
 942             /* Look for non-removable devices that return NOT_READY.  
 943              * Issue command to spin up drive for these cases. */
 944             if(the_result && !rscsi_disks[i].device->removable && 
 945                SCpnt->sense_buffer[2] == NOT_READY) {
 946                 int time1;
 947                 if(!spintime){
 948                     printk( "sd%c: Spinning up disk...", 'a' + i );
 949                     cmd[0] = START_STOP;
 950                     cmd[1] = (rscsi_disks[i].device->lun << 5) & 0xe0;
 951                     cmd[1] |= 1;  /* Return immediately */
 952                     memset ((void *) &cmd[2], 0, 8);
 953                     cmd[4] = 1; /* Start spin cycle */
 954                     /* Mark as really busy again */
 955                     SCpnt->request.dev = 0xffff; 
 956                     SCpnt->cmd_len = 0;
 957                     SCpnt->sense_buffer[0] = 0;
 958                     SCpnt->sense_buffer[2] = 0;
 959                     
 960                     scsi_do_cmd (SCpnt,
 961                                  (void *) cmd, (void *) buffer,
 962                                  512, sd_init_done,  SD_TIMEOUT,
 963                                  MAX_RETRIES);
 964                     
 965                     while(SCpnt->request.dev != 0xfffe)
 966             barrier();
 967                     
 968                     spintime = jiffies;
 969                 };
 970                 
 971                 time1 = jiffies;
 972                 while(jiffies < time1 + HZ); /* Wait 1 second for next try */
 973                 printk( "." );
 974             };
 975         } while(the_result && spintime && spintime+100*HZ > jiffies);
 976         if (spintime) {
 977             if (the_result)
 978                 printk( "not responding...\n" );
 979             else
 980                 printk( "ready\n" );
 981         }
 982     };  /* current->pid == 0 */
 983     
 984     
 985     retries = 3;
 986     do {
 987         cmd[0] = READ_CAPACITY;
 988         cmd[1] = (rscsi_disks[i].device->lun << 5) & 0xe0;
 989         memset ((void *) &cmd[2], 0, 8);
 990         memset ((void *) buffer, 0, 8);
 991         SCpnt->request.dev = 0xffff;  /* Mark as really busy again */
 992         SCpnt->cmd_len = 0;
 993         SCpnt->sense_buffer[0] = 0;
 994         SCpnt->sense_buffer[2] = 0;
 995         
 996         scsi_do_cmd (SCpnt,
 997                      (void *) cmd, (void *) buffer,
 998                      8, sd_init_done,  SD_TIMEOUT,
 999                      MAX_RETRIES);
1000         
1001         if (current->pid == 0)
1002             while(SCpnt->request.dev != 0xfffe)
1003         barrier();
1004         else
1005             if (SCpnt->request.dev != 0xfffe){
1006                 struct semaphore sem = MUTEX_LOCKED;
1007                 SCpnt->request.sem = &sem;
1008                 down(&sem);
1009                 /* Hmm.. Have to ask about this one.. */
1010                 while (SCpnt->request.dev != 0xfffe) 
1011             schedule();
1012             };
1013         
1014         the_result = SCpnt->result;
1015         retries--;
1016         
1017     } while(the_result && retries);
1018     
1019     SCpnt->request.dev = -1;  /* Mark as not busy */
1020     
1021     wake_up(&SCpnt->device->device_wait); 
1022     
1023     /* Wake up a process waiting for device */
1024     
1025     /*
1026      * The SCSI standard says: 
1027      * "READ CAPACITY is necessary for self configuring software"
1028      *  While not mandatory, support of READ CAPACITY is strongly encouraged.
1029      *  We used to die if we couldn't successfully do a READ CAPACITY.
1030      *  But, now we go on about our way.  The side effects of this are
1031      *
1032      *  1. We can't know block size with certainty. I have said "512 bytes 
1033      *     is it" as this is most common.
1034      *
1035      *  2. Recovery from when some one attempts to read past the end of the 
1036      *     raw device will be slower.
1037      */
1038     
1039     if (the_result)
1040     {
1041         printk ("sd%c : READ CAPACITY failed.\n"
1042                 "sd%c : status = %x, message = %02x, host = %d, driver = %02x \n",
1043                 'a' + i, 'a' + i,
1044                 status_byte(the_result),
1045                 msg_byte(the_result),
1046                 host_byte(the_result),
1047                 driver_byte(the_result)
1048                 );
1049         if (driver_byte(the_result)  & DRIVER_SENSE)
1050             printk("sd%c : extended sense code = %1x \n", 
1051                    'a' + i, SCpnt->sense_buffer[2] & 0xf);
1052         else
1053             printk("sd%c : sense not available. \n", 'a' + i);
1054         
1055         printk("sd%c : block size assumed to be 512 bytes, disk size 1GB.  \n",
1056                'a' + i);
1057         rscsi_disks[i].capacity = 0x1fffff;
1058         rscsi_disks[i].sector_size = 512;
1059         
1060         /* Set dirty bit for removable devices if not ready - sometimes drives
1061          * will not report this properly. */
1062         if(rscsi_disks[i].device->removable && 
1063            SCpnt->sense_buffer[2] == NOT_READY)
1064             rscsi_disks[i].device->changed = 1;
1065         
1066     }
1067     else
1068     {
1069         rscsi_disks[i].capacity = (buffer[0] << 24) |
1070             (buffer[1] << 16) |
1071                 (buffer[2] << 8) |
1072                     buffer[3];
1073         
1074         rscsi_disks[i].sector_size = (buffer[4] << 24) |
1075             (buffer[5] << 16) | (buffer[6] << 8) | buffer[7];
1076         
1077         if (rscsi_disks[i].sector_size != 512 &&
1078             rscsi_disks[i].sector_size != 1024 &&
1079             rscsi_disks[i].sector_size != 256)
1080         {
1081             printk ("sd%c : unsupported sector size %d.\n",
1082                     'a' + i, rscsi_disks[i].sector_size);
1083             if(rscsi_disks[i].device->removable){
1084                 rscsi_disks[i].capacity = 0;
1085             } else {
1086                 printk ("scsi : deleting disk entry.\n");
1087                 rscsi_disks[i].device = NULL;
1088                 sd_template.nr_dev--;
1089                 return i;
1090             };
1091         }
1092     {
1093         /*
1094          * The msdos fs need to know the hardware sector size
1095          * So I have created this table. See ll_rw_blk.c
1096          * Jacques Gelinas (Jacques@solucorp.qc.ca)
1097          */
1098         int m;
1099         int hard_sector = rscsi_disks[i].sector_size;
1100         /* There is 16 minor allocated for each devices */
1101         for (m=i<<4; m<((i+1)<<4); m++){
1102             sd_hardsizes[m] = hard_sector;
1103         }
1104         printk ("SCSI Hardware sector size is %d bytes on device sd%c\n",
1105                 hard_sector,i+'a');
1106     }
1107         if(rscsi_disks[i].sector_size == 1024)
1108             rscsi_disks[i].capacity <<= 1;  /* Change into 512 byte sectors */
1109         if(rscsi_disks[i].sector_size == 256)
1110             rscsi_disks[i].capacity >>= 1;  /* Change into 512 byte sectors */
1111     }
1112     
1113     rscsi_disks[i].ten = 1;
1114     rscsi_disks[i].remap = 1;
1115     scsi_free(buffer, 512);
1116     return i;
1117 }
1118 
1119 /*
1120  * The sd_init() function looks at all SCSI drives present, determines
1121  * their size, and reads partition table entries for them.
1122  */
1123 
1124 
1125 static void sd_init()
     /* [previous][next][first][last][top][bottom][index][help] */
1126 {
1127     int i;
1128     static int sd_registered = 0;
1129     
1130     if (sd_template.dev_noticed == 0) return;
1131     
1132     if(!sd_registered) {
1133           if (register_blkdev(MAJOR_NR,"sd",&sd_fops)) {
1134               printk("Unable to get major %d for SCSI disk\n",MAJOR_NR);
1135               return;
1136           }
1137           sd_registered++;
1138       }
1139     
1140     /* We do not support attaching loadable devices yet. */
1141     if(rscsi_disks) return;
1142     
1143     sd_template.dev_max = sd_template.dev_noticed + SD_EXTRA_DEVS;
1144     
1145     rscsi_disks = (Scsi_Disk *) 
1146         scsi_init_malloc(sd_template.dev_max * sizeof(Scsi_Disk), GFP_ATOMIC);
1147     memset(rscsi_disks, 0, sd_template.dev_max * sizeof(Scsi_Disk));
1148     
1149     sd_sizes = (int *) scsi_init_malloc((sd_template.dev_max << 4) * 
1150                                         sizeof(int), GFP_ATOMIC);
1151     memset(sd_sizes, 0, (sd_template.dev_max << 4) * sizeof(int));
1152     
1153     sd_blocksizes = (int *) scsi_init_malloc((sd_template.dev_max << 4) * 
1154                                              sizeof(int), GFP_ATOMIC);
1155     
1156     sd_hardsizes = (int *) scsi_init_malloc((sd_template.dev_max << 4) * 
1157                                             sizeof(int), GFP_ATOMIC);
1158     
1159     for(i=0;i<(sd_template.dev_max << 4);i++){
1160         sd_blocksizes[i] = 1024;
1161         sd_hardsizes[i] = 512;
1162     }
1163     blksize_size[MAJOR_NR] = sd_blocksizes;
1164     hardsect_size[MAJOR_NR] = sd_hardsizes;
1165     sd = (struct hd_struct *) scsi_init_malloc((sd_template.dev_max << 4) *
1166                                                sizeof(struct hd_struct),
1167                                                GFP_ATOMIC);
1168     
1169     
1170     sd_gendisk.max_nr = sd_template.dev_max;
1171     sd_gendisk.part = sd;
1172     sd_gendisk.sizes = sd_sizes;
1173     sd_gendisk.real_devices = (void *) rscsi_disks;
1174     
1175 }
1176 
1177 static void sd_finish()
     /* [previous][next][first][last][top][bottom][index][help] */
1178 {
1179     int i;
1180     
1181     blk_dev[MAJOR_NR].request_fn = DEVICE_REQUEST;
1182     
1183     sd_gendisk.next = gendisk_head;
1184     gendisk_head = &sd_gendisk;
1185     
1186     for (i = 0; i < sd_template.dev_max; ++i)
1187         if (!rscsi_disks[i].capacity && 
1188             rscsi_disks[i].device)
1189         {
1190             i = sd_init_onedisk(i);
1191             if (MODULE_FLAG
1192                 && !rscsi_disks[i].has_part_table) {
1193                 sd_sizes[i << 4] = rscsi_disks[i].capacity;
1194                 revalidate_scsidisk(i << 4, 0);
1195             }
1196             rscsi_disks[i].has_part_table = 1;
1197         }
1198     
1199     /* If our host adapter is capable of scatter-gather, then we increase
1200      * the read-ahead to 16 blocks (32 sectors).  If not, we use
1201      * a two block (4 sector) read ahead. 
1202      */
1203     if(rscsi_disks[0].device && rscsi_disks[0].device->host->sg_tablesize)
1204         read_ahead[MAJOR_NR] = 120;
1205     /* 64 sector read-ahead */
1206     else
1207         read_ahead[MAJOR_NR] = 4;  /* 4 sector read-ahead */
1208     
1209     return;
1210 }
1211 
1212 static int sd_detect(Scsi_Device * SDp){
     /* [previous][next][first][last][top][bottom][index][help] */
1213     if(SDp->type != TYPE_DISK && SDp->type != TYPE_MOD) return 0;
1214     
1215     printk("Detected scsi disk sd%c at scsi%d, channel %d, id %d, lun %d\n", 
1216            'a'+ (sd_template.dev_noticed++),
1217            SDp->host->host_no, SDp->channel, SDp->id, SDp->lun); 
1218     
1219     return 1;
1220 }
1221 
1222 static int sd_attach(Scsi_Device * SDp){
     /* [previous][next][first][last][top][bottom][index][help] */
1223     Scsi_Disk * dpnt;
1224     int i;
1225     
1226     if(SDp->type != TYPE_DISK && SDp->type != TYPE_MOD) return 0;
1227     
1228     if(sd_template.nr_dev >= sd_template.dev_max) {
1229         SDp->attached--;
1230         return 1;
1231     }
1232     
1233     for(dpnt = rscsi_disks, i=0; i<sd_template.dev_max; i++, dpnt++) 
1234         if(!dpnt->device) break;
1235     
1236     if(i >= sd_template.dev_max) panic ("scsi_devices corrupt (sd)");
1237     
1238     SDp->scsi_request_fn = do_sd_request;
1239     rscsi_disks[i].device = SDp;
1240     rscsi_disks[i].has_part_table = 0;
1241     sd_template.nr_dev++;
1242     sd_gendisk.nr_real++;
1243     return 0;
1244 }
1245 
1246 #define DEVICE_BUSY rscsi_disks[target].device->busy
1247 #define USAGE rscsi_disks[target].device->access_count
1248 #define CAPACITY rscsi_disks[target].capacity
1249 #define MAYBE_REINIT  sd_init_onedisk(target)
1250 #define GENDISK_STRUCT sd_gendisk
1251 
1252 /* This routine is called to flush all partitions and partition tables
1253  * for a changed scsi disk, and then re-read the new partition table.
1254  * If we are revalidating a disk because of a media change, then we
1255  * enter with usage == 0.  If we are using an ioctl, we automatically have
1256  * usage == 1 (we need an open channel to use an ioctl :-), so this
1257  * is our limit.
1258  */
1259 int revalidate_scsidisk(int dev, int maxusage){
     /* [previous][next][first][last][top][bottom][index][help] */
1260     int target, major;
1261     struct gendisk * gdev;
1262     unsigned long flags;
1263     int max_p;
1264     int start;
1265     int i;
1266     
1267     target =  DEVICE_NR(MINOR(dev));
1268     gdev = &GENDISK_STRUCT;
1269     
1270     save_flags(flags);
1271     cli();
1272     if (DEVICE_BUSY || USAGE > maxusage) {
1273         restore_flags(flags);
1274         printk("Device busy for revalidation (usage=%d)\n", USAGE);
1275         return -EBUSY;
1276     };
1277     DEVICE_BUSY = 1;
1278     restore_flags(flags);
1279     
1280     max_p = gdev->max_p;
1281     start = target << gdev->minor_shift;
1282     major = MAJOR_NR << 8;
1283     
1284     for (i=max_p - 1; i >=0 ; i--) {
1285         sync_dev(major | start | i);
1286         invalidate_inodes(major | start | i);
1287         invalidate_buffers(major | start | i);
1288         gdev->part[start+i].start_sect = 0;
1289         gdev->part[start+i].nr_sects = 0;
1290     };
1291     
1292 #ifdef MAYBE_REINIT
1293     MAYBE_REINIT;
1294 #endif
1295     
1296     gdev->part[start].nr_sects = CAPACITY;
1297     resetup_one_dev(gdev, target);
1298     
1299     DEVICE_BUSY = 0;
1300     return 0;
1301 }
1302 
1303 static int fop_revalidate_scsidisk(dev_t dev){
     /* [previous][next][first][last][top][bottom][index][help] */
1304     return revalidate_scsidisk(dev, 0);
1305 }
1306 
1307 
1308 static void sd_detach(Scsi_Device * SDp)
     /* [previous][next][first][last][top][bottom][index][help] */
1309 {
1310     Scsi_Disk * dpnt;
1311     int i;
1312     int max_p;
1313     int major;
1314     int start;
1315     
1316     for(dpnt = rscsi_disks, i=0; i<sd_template.dev_max; i++, dpnt++) 
1317         if(dpnt->device == SDp) {
1318             
1319             /* If we are disconnecting a disk driver, sync and invalidate 
1320              * everything */
1321             max_p = sd_gendisk.max_p;
1322             start = i << sd_gendisk.minor_shift;
1323             major = MAJOR_NR << 8;
1324             
1325             for (i=max_p - 1; i >=0 ; i--) {
1326                 sync_dev(major | start | i);
1327                 invalidate_inodes(major | start | i);
1328                 invalidate_buffers(major | start | i);
1329                 sd_gendisk.part[start+i].start_sect = 0;
1330                 sd_gendisk.part[start+i].nr_sects = 0;
1331                 sd_sizes[start+i] = 0;
1332             };
1333             
1334             dpnt->has_part_table = 0;
1335             dpnt->device = NULL;
1336             dpnt->capacity = 0;
1337             SDp->attached--;
1338             sd_template.dev_noticed--;
1339             sd_template.nr_dev--;
1340             sd_gendisk.nr_real--;
1341             return;
1342         }
1343     return;
1344 }
1345 
1346 #ifdef MODULE
1347 #include <linux/module.h>
1348 #include <linux/version.h>
1349 
1350 char kernel_version[] = UTS_RELEASE;
1351 
1352 int init_module(void) {
     /* [previous][next][first][last][top][bottom][index][help] */
1353     sd_template.usage_count = &mod_use_count_;
1354     return scsi_register_module(MODULE_SCSI_DEV, &sd_template);
1355 }
1356 
1357 void cleanup_module( void) 
     /* [previous][next][first][last][top][bottom][index][help] */
1358 {
1359     struct gendisk * prev_sdgd;
1360     struct gendisk * sdgd;
1361     
1362     if (MOD_IN_USE) {
1363         printk(KERN_INFO __FILE__ ": module is in use, remove rejected\n");
1364         return;
1365     }
1366     scsi_unregister_module(MODULE_SCSI_DEV, &sd_template);
1367     unregister_blkdev(SCSI_GENERIC_MAJOR, "sd");
1368     if( rscsi_disks != NULL )
1369     {
1370         scsi_init_free((char *) rscsi_disks,
1371                        (sd_template.dev_noticed + SD_EXTRA_DEVS) 
1372                        * sizeof(Scsi_Disk));
1373         
1374         scsi_init_free((char *) sd_sizes, sd_template.dev_max * sizeof(int));
1375         scsi_init_free((char *) sd_blocksizes, sd_template.dev_max * sizeof(int));
1376         scsi_init_free((char *) sd_hardsizes, sd_template.dev_max * sizeof(int));
1377         scsi_init_free((char *) sd, 
1378                        (sd_template.dev_max << 4) * sizeof(struct hd_struct));
1379         /*
1380          * Now remove sd_gendisk from the linked list
1381          */
1382         sdgd = gendisk_head;
1383         prev_sdgd = NULL;
1384         while(sdgd != &sd_gendisk)
1385         {
1386             prev_sdgd = sdgd;
1387             sdgd = sdgd->next;
1388         }
1389         
1390         if(sdgd != &sd_gendisk)
1391             printk("sd_gendisk not in disk chain.\n");
1392         else {
1393             if(prev_sdgd != NULL)
1394                 prev_sdgd->next = sdgd->next;
1395             else
1396                 gendisk_head = sdgd->next;
1397         }
1398     }
1399     
1400     blksize_size[MAJOR_NR] = NULL;
1401     blk_dev[MAJOR_NR].request_fn = NULL;
1402     blk_size[MAJOR_NR] = NULL;  
1403     hardsect_size[MAJOR_NR] = NULL;
1404     read_ahead[MAJOR_NR] = 0;
1405     sd_template.dev_max = 0;
1406 }
1407 #endif /* MODULE */
1408 
1409 /*
1410  * Overrides for Emacs so that we almost follow Linus's tabbing style.
1411  * Emacs will notice this stuff at the end of the file and automatically
1412  * adjust the settings for this buffer only.  This must remain at the end
1413  * of the file.
1414  * ---------------------------------------------------------------------------
1415  * Local variables:
1416  * c-indent-level: 4
1417  * c-brace-imaginary-offset: 0
1418  * c-brace-offset: -4
1419  * c-argdecl-indent: 4
1420  * c-label-offset: -4
1421  * c-continued-statement-offset: 4
1422  * c-continued-brace-offset: 0
1423  * indent-tabs-mode: nil
1424  * tab-width: 8
1425  * End:
1426  */

/* [previous][next][first][last][top][bottom][index][help] */