亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? aha152x.c

?? 內核是系統的心臟
?? C
?? 第 1 頁 / 共 5 頁
字號:

/*
   Test, if port_base is valid.
 */
static int aha152x_porttest(int port_base)
{
  int i;

  if(check_region(port_base, TEST-SCSISEQ))
    return 0;

  SETPORT( DMACNTRL1, 0 );          /* reset stack pointer */
  for(i=0; i<16; i++)
    SETPORT( STACK, i );

  SETPORT( DMACNTRL1, 0 );          /* reset stack pointer */
  for(i=0; i<16 && GETPORT(STACK)==i; i++)
    ;

  return(i==16);
}

int aha152x_detect(int hostno)
{
  int                 i, j,  ok;
  aha152x_config      conf;
  struct sigaction    sa;
  int                 interrupt_level;
  
#if defined(DEBUG_RACE)
  enter_driver("detect");
#endif
  
  printk("aha152x: Probing: ");

  if(setup_called)
    {
      printk("processing commandline: ");
   
      if(setup_called!=4)
        {
          printk("\naha152x: %s\n", setup_str );
          printk("aha152x: usage: aha152x=<PORTBASE>,<IRQ>,<SCSI ID>,<RECONNECT>\n");
          panic("aha152x panics in line %d", __LINE__);
        }

      port_base       = setup_portbase;
      interrupt_level = setup_irq;
      this_host       = setup_scsiid;
      can_disconnect  = setup_reconnect;

      for( i=0; i<PORT_COUNT && (port_base != ports[i]); i++)
        ;

      if(i==PORT_COUNT)
        {
          printk("unknown portbase 0x%03x\n", port_base);
          panic("aha152x panics in line %d", __LINE__);
        }

      if(!aha152x_porttest(port_base))
        {
          printk("portbase 0x%03x fails probe\n", port_base);
          panic("aha152x panics in line %d", __LINE__);
        }

      i=0;
      while(ints[i] && (interrupt_level!=ints[i]))
        i++;
      if(!ints[i])
        {
          printk("illegal IRQ %d\n", interrupt_level);
          panic("aha152x panics in line %d", __LINE__);
        }

      if( (this_host < 0) || (this_host > 7) )
        {
          printk("illegal SCSI ID %d\n", this_host);
          panic("aha152x panics in line %d", __LINE__);
        }

      if( (can_disconnect < 0) || (can_disconnect > 1) )
        {
          printk("reconnect %d should be 0 or 1\n", can_disconnect);
          panic("aha152x panics in line %d", __LINE__);
        }
      printk("ok, ");
    }
  else
    {
#if !defined(SKIP_BIOSTEST)
      printk("BIOS test: ");
      ok=0;
      for( i=0; i < ADDRESS_COUNT && !ok; i++)
        for( j=0; (j < SIGNATURE_COUNT) && !ok; j++)
          ok=!memcmp((void *) addresses[i]+signatures[j].sig_offset,
                     (void *) signatures[j].signature,
                     (int) signatures[j].sig_length);

      if(!ok)
        {
#if defined(DEBUG_RACE)
          leave_driver("(1) detect");
#endif
          printk("failed\n");
          return 0;
        }
      printk("ok, ");
#endif /* !SKIP_BIOSTEST */
 
#if !defined(PORTBASE)
      printk("porttest: ");
      for( i=0; i<PORT_COUNT && !aha152x_porttest(ports[i]); i++)
        ;

      if(i==PORT_COUNT)
        {
          printk("failed\n");
#if defined(DEBUG_RACE)
          leave_driver("(2) detect");
#endif
          return 0;
        }
      else
        port_base=ports[i];
      printk("ok, ");
#else
      port_base=PORTBASE;
#endif /* !PORTBASE */

#if defined(AUTOCONF)

      conf.cf_port = (GETPORT(PORTA)<<8) + GETPORT(PORTB);

      interrupt_level = ints[conf.cf_irq];
      this_host       = conf.cf_id;
      can_disconnect  = conf.cf_tardisc;

      printk("auto configuration: ok, ");

#endif /* AUTOCONF */

#if defined(IRQ)
      interrupt_level = IRQ; 
#endif

#if defined(SCSI_ID)
      this_host = SCSI_ID;
#endif

#if defined(RECONNECT)
      can_disconnect=RECONNECT;
#endif
    }

  printk("detection complete\n");
 
  sa.sa_handler  = aha152x_intr;
  sa.sa_flags    = SA_INTERRUPT;
  sa.sa_mask     = 0;
  sa.sa_restorer = NULL;
  
  ok = irqaction( interrupt_level, &sa);
  
  if(ok<0)
    {
      if(ok == -EINVAL)
        {
           printk("aha152x: bad IRQ %d.\n", interrupt_level);
           printk("         Contact author.\n");
        }
      else
        if( ok == -EBUSY)
          printk( "aha152x: IRQ %d already in use. Configure another.\n",
                  interrupt_level);
        else
          {
            printk( "\naha152x: Unexpected error code on requesting IRQ %d.\n",
                    interrupt_level);
            printk("         Contact author.\n");
          }
      panic("aha152x: driver needs an IRQ.\n");
    }

  SETPORT( SCSIID, this_host << 4 );
  scsi_hosts[hostno].this_id=this_host;
  
  if(can_disconnect)
    scsi_hosts[hostno].can_queue=AHA152X_MAXQUEUE;

  /* RESET OUT */
  SETBITS(SCSISEQ, SCSIRSTO );
  do_pause(5);
  CLRBITS(SCSISEQ, SCSIRSTO );
  do_pause(10);

  aha152x_reset(NULL);

  printk("aha152x: vital data: PORTBASE=0x%03x, IRQ=%d, SCSI ID=%d, reconnect=%s, parity=enabled\n",
         port_base, interrupt_level, this_host, can_disconnect ? "enabled" : "disabled" );

  snarf_region(port_base, TEST-SCSISEQ);        /* Register */
  
  /* not expecting any interrupts */
  SETPORT(SIMODE0, 0);
  SETPORT(SIMODE1, 0);

#if defined(DEBUG_RACE)
  leave_driver("(3) detect");
#endif

  SETBITS( DMACNTRL0, INTEN);
  return 1;
}

/*
 *  return the name of the thing
 */
const char *aha152x_info(void)
{
#if defined(DEBUG_RACE)
  enter_driver("info");
  leave_driver("info");
#else
#if defined(DEBUG_INFO)
  printk("\naha152x: info()\n");
#endif
#endif
  return(aha152x_id);
}

/* 
 *  Queue a command and setup interrupts for a free bus.
 */
int aha152x_queue( Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *))
{
#if defined(DEBUG_RACE)
  enter_driver("queue");
#else
#if defined(DEBUG_QUEUE)
  printk("aha152x: queue(), ");
#endif
#endif


#if defined(DEBUG_QUEUE)
  printk( "SCpnt (target = %d lun = %d cmnd = 0x%02x pieces = %d size = %u), ",
          SCpnt->target,
          SCpnt->lun,
          *(unsigned char *)SCpnt->cmnd,
          SCpnt->use_sg,
          SCpnt->request_bufflen );
  disp_ports();
#endif

  SCpnt->scsi_done =       done;

  /* setup scratch area
     SCp.ptr              : buffer pointer
     SCp.this_residual    : buffer length
     SCp.buffer           : next buffer
     SCp.buffers_residual : left buffers in list
     SCp.phase            : current state of the command */
  SCpnt->SCp.phase = not_issued;
  if (SCpnt->use_sg)
    {
      SCpnt->SCp.buffer           = (struct scatterlist *)SCpnt->request_buffer;
      SCpnt->SCp.ptr              = SCpnt->SCp.buffer->address;
      SCpnt->SCp.this_residual    = SCpnt->SCp.buffer->length;
      SCpnt->SCp.buffers_residual = SCpnt->use_sg - 1;
    }
  else
    {
      SCpnt->SCp.ptr              = (char *)SCpnt->request_buffer;
      SCpnt->SCp.this_residual    = SCpnt->request_bufflen;
      SCpnt->SCp.buffer           = NULL;
      SCpnt->SCp.buffers_residual = 0;
    }
          
  SCpnt->SCp.Status              = CHECK_CONDITION;
  SCpnt->SCp.Message             = 0;
  SCpnt->SCp.have_data_in        = 0;
  SCpnt->SCp.sent_command        = 0;

  /* Turn led on, when this is the first command. */
  cli();
  commands++;
  if(commands==1)
    SETPORT( PORTA, 1 );

#if defined(DEBUG_QUEUES)
  printk("i+ (%d), ", commands );
#endif
  append_SC( &issue_SC, SCpnt);
  
  /* Enable bus free interrupt, when we aren't currently on the bus */
  if(!current_SC)
    {
      SETPORT(SIMODE0, disconnected_SC ? ENSELDI : 0 );
      SETPORT(SIMODE1, issue_SC ? ENBUSFREE : 0);
    }
  sti();

  return 0;
}

/*
 *  We only support command in interrupt-driven fashion
 */
int aha152x_command( Scsi_Cmnd *SCpnt )
{
  printk( "aha152x: interrupt driven driver; use aha152x_queue()\n" );
  return -1;
}

/*
 *  Abort a queued command
 *  (commands that are on the bus can't be aborted easily)
 */
int aha152x_abort( Scsi_Cmnd *SCpnt, int code )
{
  Scsi_Cmnd *ptr, *prev;

  cli();

#if defined(DEBUG_ABORT)
  printk("aha152x: abort(), SCpnt=0x%08x, ", (unsigned long) SCpnt );
#endif

  show_queues();

  /* look for command in issue queue */
  for( ptr=issue_SC, prev=NULL;
       ptr && ptr!=SCpnt;
       prev=ptr, ptr=(Scsi_Cmnd *) ptr->host_scribble)
    ;

  if(ptr)
    {
      /* dequeue */
      if(prev)
        prev->host_scribble = ptr->host_scribble;
      else
        issue_SC = (Scsi_Cmnd *) ptr->host_scribble;
      sti();

      ptr->host_scribble = NULL;
      ptr->result = (code ? code : DID_ABORT ) << 16;
      ptr->done(ptr);
      return 0;
    }

  /* Fail abortion, if we're on the bus */
  if (current_SC)
    {
       sti();
       return -1;
    }

  /* look for command in disconnected queue */
  for( ptr=disconnected_SC, prev=NULL;
       ptr && ptr!=SCpnt;
       prev=ptr, ptr=(Scsi_Cmnd *) ptr->host_scribble)
    ;

  if(ptr && TESTLO(SSTAT1, BUSFREE) )
    printk("bus busy but no current command, ");

  if(ptr && TESTHI(SSTAT1, BUSFREE) )
    {
      /* dequeue */
      if(prev)
        prev->host_scribble = ptr->host_scribble;
      else
        issue_SC = (Scsi_Cmnd *) ptr->host_scribble;

      /* set command current and initiate selection,
         let the interrupt routine take care of the abortion */
      current_SC     = ptr;
      ptr->SCp.phase = in_selection|aborted;
      SETPORT( SCSIID, (this_host << OID_) | current_SC->target );

      /* enable interrupts for SELECTION OUT DONE and SELECTION TIME OUT */
      SETPORT( SIMODE0, ENSELDO | (disconnected_SC ? ENSELDI : 0) );
      SETPORT( SIMODE1, ENSELTIMO );

      /* Enable SELECTION OUT sequence */
      SETBITS(SCSISEQ, ENSELO | ENAUTOATNO );

      SETBITS( DMACNTRL0, INTEN );
      abort_result=0;
      sti();

      /* sleep until the abortion is complete */
      sleep_on( &abortion_complete );
      return abort_result;
    }
  else
    printk("aha152x: bus busy but no current command\n");

  /* command wasn't found */
  sti();
  return 0;
}

/*
 *  Restore default values to the AIC-6260 registers and reset the fifos
 */
static void aha152x_reset_ports(void)
{
  /* disable interrupts */
  SETPORT(DMACNTRL0, RSTFIFO);

  SETPORT(SCSISEQ, 0);

  SETPORT(SXFRCTL1, 0);
  SETPORT( SCSISIG, 0);
  SETPORT(SCSIRATE, 0);

  /* clear all interrupt conditions */
  SETPORT(SSTAT0, 0x7f);
  SETPORT(SSTAT1, 0xef);

  SETPORT(SSTAT4, SYNCERR|FWERR|FRERR);

  SETPORT(DMACNTRL0, 0);
  SETPORT(DMACNTRL1, 0);

  SETPORT(BRSTCNTRL, 0xf1);

  /* clear SCSI fifo and transfer count */
  SETPORT(SXFRCTL0, CH1|CLRCH1|CLRSTCNT);
  SETPORT(SXFRCTL0, CH1);

  /* enable interrupts */
  SETPORT(SIMODE0, disconnected_SC ? ENSELDI : 0 );
  SETPORT(SIMODE1, issue_SC ? ENBUSFREE : 0);
}

/*
 *  Reset registers, reset a hanging bus and
 *  kill active and disconnected commands
 */
int aha152x_reset(Scsi_Cmnd * __unused)
{
  Scsi_Cmnd *ptr;

  aha152x_reset_ports();

  /* Reset, if bus hangs */
  if( TESTLO( SSTAT1, BUSFREE ) )
    {
       CLRBITS( DMACNTRL0, INTEN );

#if defined( DEBUG_RESET )
       printk("aha152x: reset(), bus not free: SCSI RESET OUT\n");
#endif

       show_queues();

       if(current_SC)
         {
           current_SC->host_scribble = NULL;
           current_SC->result = DID_RESET << 16;
           current_SC->done(current_SC);
           current_SC=NULL;
         }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区蝌蚪| 精品噜噜噜噜久久久久久久久试看 | 欧美亚洲另类激情小说| 成人免费视频国产在线观看| 麻豆91在线观看| 麻豆91精品91久久久的内涵| 国产福利电影一区二区三区| 亚洲免费av在线| 国产精品素人视频| 国产精品色噜噜| 色综合久久88色综合天天 | 狠狠v欧美v日韩v亚洲ⅴ| 日本一区二区三区久久久久久久久不 | 日韩三级视频中文字幕| 国产成人在线免费观看| 亚洲国产精品久久久男人的天堂| 久久这里只有精品6| 日韩午夜电影av| 欧美日韩黄色影视| 91丨国产丨九色丨pron| 国产高清一区日本| 日韩国产一区二| 看片网站欧美日韩| 日韩不卡手机在线v区| 午夜a成v人精品| 国产精品久久99| 欧美日韩久久一区二区| 97久久精品人人澡人人爽| 粉嫩一区二区三区在线看| 91精品国产色综合久久| 国产精品69久久久久水密桃| 亚洲欧美激情视频在线观看一区二区三区 | 色香色香欲天天天影视综合网| 一本一道久久a久久精品| 婷婷久久综合九色综合绿巨人| 国产喂奶挤奶一区二区三区| 久久无码av三级| 久久久久99精品国产片| 欧美激情在线免费观看| 亚洲欧洲99久久| 最近日韩中文字幕| 亚洲在线视频一区| 亚洲成人在线免费| 精东粉嫩av免费一区二区三区| 日韩在线一二三区| 国内成人精品2018免费看| 国产精品456露脸| www.日韩精品| 欧美视频一区二区三区在线观看| 欧美色中文字幕| 久久久噜噜噜久久中文字幕色伊伊| 国产精品你懂的| 日韩有码一区二区三区| 国内精品在线播放| 欧美天堂一区二区三区| 日韩精品最新网址| 国产精品久久夜| 欧美在线三级电影| 欧美日韩的一区二区| 亚洲综合图片区| 亚洲视频网在线直播| 国产精品入口麻豆原神| 亚洲成精国产精品女| 色婷婷综合在线| 久久精品国产久精国产| 中文字幕制服丝袜一区二区三区| 欧美成人精品3d动漫h| 一色桃子久久精品亚洲| 久久99国产精品尤物| 99久久精品费精品国产一区二区| 91精品国产91久久久久久一区二区| 中文av字幕一区| 麻豆免费精品视频| 色一情一乱一乱一91av| 国产一区二区三区av电影 | 国内精品久久久久影院薰衣草| 国产盗摄女厕一区二区三区 | 亚洲一区二区精品视频| 精品一区二区三区久久久| 欧美少妇xxx| 一区二区三区四区在线播放| 成人禁用看黄a在线| 中文字幕一区二区三区av| 奇米在线7777在线精品| 欧美一区二区黄色| 日欧美一区二区| 欧美日韩另类一区| 天天影视网天天综合色在线播放| 色婷婷久久久综合中文字幕 | 色婷婷久久99综合精品jk白丝| 日韩一级二级三级| 美女www一区二区| 久久精品这里都是精品| 丰满放荡岳乱妇91ww| 中文字幕乱码亚洲精品一区| 欧美一区二区视频在线观看| 五月天网站亚洲| 中文字幕人成不卡一区| 国产成人av资源| 日韩高清不卡在线| 国产精品欧美久久久久一区二区| 日韩亚洲欧美一区| 91免费国产在线观看| 亚洲成人久久影院| 6080yy午夜一二三区久久| 亚洲精品国产a| 欧美精品久久一区| 国产一区二区三区免费看| 一区二区在线观看av| 亚洲成av人片在线观看| 日韩国产精品大片| 奇米一区二区三区| 欧美一区二区三区免费观看视频| www.爱久久.com| 国产人伦精品一区二区| 成人免费av资源| 亚洲人123区| 91精品福利在线| 亚洲成人手机在线| 欧美一区二区三区四区高清| 亚洲在线视频免费观看| 久久综合狠狠综合久久激情 | 黄色日韩网站视频| 欧美国产欧美亚州国产日韩mv天天看完整 | 亚洲已满18点击进入久久| 91.麻豆视频| 91久久精品午夜一区二区| 国产一区在线精品| 免费人成精品欧美精品| 樱桃国产成人精品视频| 国产精品网站在线观看| 精品国产sm最大网站免费看| 日本韩国精品在线| 国产精品1区2区3区| 欧美日韩激情一区二区| 91激情在线视频| 91一区二区三区在线观看| proumb性欧美在线观看| 国产盗摄一区二区三区| 国产一区二区三区精品视频| 亚洲成av人片在线观看无码| 一区二区三区在线观看视频| 久久99国产乱子伦精品免费| 亚洲一二三四在线| 国产一区二区三区在线观看精品| 国产91综合网| 午夜精品视频在线观看| 国产精品毛片久久久久久久| 蜜臀久久久久久久| 日韩天堂在线观看| 欧美丝袜第三区| 美腿丝袜亚洲色图| 中文字幕制服丝袜成人av| 欧美午夜在线观看| 国产一区二区看久久| 亚洲欧美韩国综合色| 欧美大片免费久久精品三p| 成人在线一区二区三区| 亚洲国产综合91精品麻豆| 久久嫩草精品久久久精品一| 色欧美片视频在线观看在线视频| 蜜臀av一区二区三区| 国产精品另类一区| 亚洲综合久久av| 免费在线观看不卡| 成人av免费网站| 91精品国产综合久久久蜜臀图片| 欧美一区二区成人| 国产精品对白交换视频| 一区二区三区国产精品| 三级不卡在线观看| 国产精品一区二区三区99| 成人av小说网| 欧美一区二区视频在线观看| 国产精品三级视频| 免费观看一级特黄欧美大片| 国产69精品一区二区亚洲孕妇| 色天天综合久久久久综合片| 精品美女在线播放| 亚洲最新在线观看| 不卡高清视频专区| 正在播放一区二区| 亚洲一级电影视频| 95精品视频在线| 欧美sm极限捆绑bd| 午夜成人在线视频| 欧美无砖专区一中文字| 国产精品美女久久福利网站 | 91亚洲大成网污www| 4hu四虎永久在线影院成人| 亚洲色图清纯唯美| 精品在线亚洲视频| 这里是久久伊人| 精品一区二区在线免费观看| 日韩精品最新网址| 成人一区二区三区视频| 欧美日韩国产经典色站一区二区三区| 精品国产精品一区二区夜夜嗨| 国产91精品在线观看| 国产精品性做久久久久久|