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

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

?? hd.c

?? linux下的源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
{  int i = inb_p (HD_STATUS);	// 取狀態信息。  if ((i & (BUSY_STAT | READY_STAT | WRERR_STAT | SEEK_STAT | ERR_STAT))      == (READY_STAT | SEEK_STAT))      return (0);		/* ok */  if (i & 1)      i = inb (HD_ERROR);	// 若ERR_STAT 置位,則讀取錯誤寄存器。    return (1);}//// 向硬盤控制器發送命令塊(參見列表后的說明)。// 調用參數:drive - 硬盤號(0-1); nsect - 讀寫扇區數;// sect - 起始扇區; head - 磁頭號;// cyl - 柱面號; cmd - 命令碼;// *intr_addr() - 硬盤中斷處理程序中將調用的C 處理函數。static void hd_out (unsigned int drive, unsigned int nsect, unsigned int sect,		    unsigned int head, unsigned int cyl, unsigned int cmd,		    void (*intr_addr) (void)){  register int port asm ("dx");	// port 變量對應寄存器dx。  if (drive > 1 || head > 15)	// 如果驅動器號(0,1)>1 或磁頭號>15,則程序不支持。    panic ("Trying to write bad sector");  if (!controller_ready ())	// 如果等待一段時間后仍未就緒則出錯,死機。    panic ("HD controller not ready");  do_hd = intr_addr;		// do_hd 函數指針將在硬盤中斷程序中被調用。  outb_p (hd_info[drive].ctl, HD_CMD);	// 向控制寄存器(0x3f6)輸出控制字節。  port = HD_DATA;		// 置dx 為數據寄存器端口(0x1f0)。  outb_p (hd_info[drive].wpcom >> 2, ++port);	// 參數:寫預補償柱面號(需除4)。  outb_p (nsect, ++port);	// 參數:讀/寫扇區總數。  outb_p (sect, ++port);	// 參數:起始扇區。  outb_p (cyl, ++port);		// 參數:柱面號低8 位。  outb_p (cyl >> 8, ++port);	// 參數:柱面號高8 位。  outb_p (0xA0 | (drive << 4) | head, ++port);	// 參數:驅動器號+磁頭號。  outb (cmd, ++port);		// 命令:硬盤控制命令。}//// 等待硬盤就緒。也即循環等待主狀態控制器忙標志位復位。若僅有就緒或尋道結束標志// 置位,則成功,返回0。若經過一段時間仍為忙,則返回1。static int drive_busy (void){  unsigned int i;  for (i = 0; i < 10000; i++)	// 循環等待就緒標志位置位。    if (READY_STAT == (inb_p (HD_STATUS) & (BUSY_STAT | READY_STAT)))        break;    i = inb (HD_STATUS);	// 再取主控制器狀態字節。    i &= BUSY_STAT | READY_STAT | SEEK_STAT;	// 檢測忙位、就緒位和尋道結束位。  if (i == READY_STAT | SEEK_STAT)	// 若僅有就緒或尋道結束標志,則返回0。      return (0);    printk ("HD controller times out\n\r");	// 否則等待超時,顯示信息。并返回1。    return (1);}//// 診斷復位(重新校正)硬盤控制器。static void reset_controller (void){  int i;    outb (4, HD_CMD);		// 向控制寄存器端口發送控制字節(4-復位)。  for (i = 0; i < 100; i++)      nop ();			// 等待一段時間(循環空操作)。    outb (hd_info[0].ctl & 0x0f, HD_CMD);	// 再發送正常的控制字節(不禁止重試、重讀)。  if (drive_busy ())		// 若等待硬盤就緒超時,則顯示出錯信息。      printk ("HD-controller still busy\n\r");  if ((i = inb (HD_ERROR)) != 1)	// 取錯誤寄存器,若不等于1(無錯誤)則出錯。      printk ("HD-controller reset failed: %02x\n\r", i);}//// 復位硬盤nr。首先復位(重新校正)硬盤控制器。然后發送硬盤控制器命令“建立驅動器參數”,// 其中recal_intr()是在硬盤中斷處理程序中調用的重新校正處理函數。static void reset_hd (int nr){  reset_controller ();  hd_out (nr, hd_info[nr].sect, hd_info[nr].sect, hd_info[nr].head - 1,	  hd_info[nr].cyl, WIN_SPECIFY, &recal_intr);}//// 意外硬盤中斷調用函數。// 發生意外硬盤中斷時,硬盤中斷處理程序中調用的默認C 處理函數。在被調用函數指針為空時// 調用該函數。參見(kernel/system_call.s,241 行)。void unexpected_hd_interrupt (void){  printk ("Unexpected HD interrupt\n\r");}//// 讀寫硬盤失敗處理調用函數。static void bad_rw_intr (void){  if (++CURRENT->errors >= MAX_ERRORS)	// 如果讀扇區時的出錯次數大于或等于7 次時,    end_request (0);		// 則結束請求并喚醒等待該請求的進程,而且// 對應緩沖區更新標志復位(沒有更新)。  if (CURRENT->errors > MAX_ERRORS / 2)	// 如果讀一扇區時的出錯次數已經大于3 次,    reset = 1;			// 則要求執行復位硬盤控制器操作。}//// 讀操作中斷調用函數。將在執行硬盤中斷處理程序中被調用。static void read_intr (void){  if (win_result ())    {				// 若控制器忙、讀寫錯或命令執行錯,      bad_rw_intr ();		// 則進行讀寫硬盤失敗處理      do_hd_request ();		// 然后再次請求硬盤作相應(復位)處理。      return;    }  port_read (HD_DATA, CURRENT->buffer, 256);	// 將數據從數據寄存器口讀到請求結構緩沖區。  CURRENT->errors = 0;		// 清出錯次數。  CURRENT->buffer += 512;	// 調整緩沖區指針,指向新的空區。  CURRENT->sector++;		// 起始扇區號加1,  if (--CURRENT->nr_sectors)    {				// 如果所需讀出的扇區數還沒有讀完,則      do_hd = &read_intr;	// 再次置硬盤調用C 函數指針為read_intr()      return;			// 因為硬盤中斷處理程序每次調用do_hd 時    }				// 都會將該函數指針置空。參見system_call.s  end_request (1);		// 若全部扇區數據已經讀完,則處理請求結束事宜,  do_hd_request ();		// 執行其它硬盤請求操作。}//// 寫扇區中斷調用函數。在硬盤中斷處理程序中被調用。// 在寫命令執行后,會產生硬盤中斷信號,執行硬盤中斷處理程序,此時在硬盤中斷處理程序中調用的// C 函數指針do_hd()已經指向write_intr(),因此會在寫操作完成(或出錯)后,執行該函數。static void write_intr (void){  if (win_result ())    {				// 如果硬盤控制器返回錯誤信息,      bad_rw_intr ();		// 則首先進行硬盤讀寫失敗處理,      do_hd_request ();		// 然后再次請求硬盤作相應(復位)處理,      return;			// 然后返回(也退出了此次硬盤中斷)。    }  if (--CURRENT->nr_sectors)    {				// 否則將欲寫扇區數減1,若還有扇區要寫,則      CURRENT->sector++;	// 當前請求起始扇區號+1,      CURRENT->buffer += 512;	// 調整請求緩沖區指針,      do_hd = &write_intr;	// 置硬盤中斷程序調用函數指針為write_intr(),      port_write (HD_DATA, CURRENT->buffer, 256);	// 再向數據寄存器端口寫256 字節。      return;			// 返回等待硬盤再次完成寫操作后的中斷處理。    }  end_request (1);		// 若全部扇區數據已經寫完,則處理請求結束事宜,  do_hd_request ();		// 執行其它硬盤請求操作。}//// 硬盤重新校正(復位)中斷調用函數。在硬盤中斷處理程序中被調用。// 如果硬盤控制器返回錯誤信息,則首先進行硬盤讀寫失敗處理,然后請求硬盤作相應(復位)處理。static void recal_intr (void){  if (win_result ())    bad_rw_intr ();  do_hd_request ();}// 執行硬盤讀寫請求操作。void do_hd_request (void){  int i, r;  unsigned int block, dev;  unsigned int sec, head, cyl;  unsigned int nsect;    INIT_REQUEST;		// 檢測請求項的合法性(參見kernel/blk_drv/blk.h,127)。// 取設備號中的子設備號(見列表后對硬盤設備號的說明)。子設備號即是硬盤上的分區號。    dev = MINOR (CURRENT->dev);	// CURRENT 定義為(blk_dev[MAJOR_NR].current_request)。    block = CURRENT->sector;	// 請求的起始扇區。// 如果子設備號不存在或者起始扇區大于該分區扇區數-2,則結束該請求,并跳轉到標號repeat 處// (定義在INIT_REQUEST 開始處)。因為一次要求讀寫2 個扇區(512*2 字節),所以請求的扇區號// 不能大于分區中最后倒數第二個扇區號。  if (dev >= 5 * NR_HD || block + 2 > hd[dev].nr_sects)    {      end_request (0);      goto repeat;		// 該標號在blk.h 最后面。    }  block += hd[dev].start_sect;	// 將所需讀的塊對應到整個硬盤上的絕對扇區號。  dev /= 5;			// 此時dev 代表硬盤號(0 或1)。// 下面嵌入匯編代碼用來從硬盤信息結構中根據起始扇區號和每磁道扇區數計算在磁道中的// 扇區號(sec)、所在柱面號(cyl)和磁頭號(head)。__asm__ ("divl %4": "=a" (block), "=d" (sec):"" (block), "1" (0),	   "r" (hd_info[dev].		sect));__asm__ ("divl %4": "=a" (cyl), "=d" (head):"" (block), "1" (0),	   "r" (hd_info[dev].		head));  sec++;  nsect = CURRENT->nr_sectors;	// 欲讀/寫的扇區數。// 如果reset 置1,則執行復位操作。復位硬盤和控制器,并置需要重新校正標志,返回。  if (reset)    {      reset = 0;      recalibrate = 1;      reset_hd (CURRENT_DEV);      return;    }// 如果重新校正標志(recalibrate)置位,則首先復位該標志,然后向硬盤控制器發送重新校正命令。  if (recalibrate)    {      recalibrate = 0;      hd_out (dev, hd_info[CURRENT_DEV].sect, 0, 0, 0,	      WIN_RESTORE, &recal_intr);      return;    }// 如果當前請求是寫扇區操作,則發送寫命令,循環讀取狀態寄存器信息并判斷請求服務標志// DRQ_STAT 是否置位。DRQ_STAT 是硬盤狀態寄存器的請求服務位(include/linux/hdreg.h,27)。  if (CURRENT->cmd == WRITE)    {      hd_out (dev, nsect, sec, head, cyl, WIN_WRITE, &write_intr);      for (i = 0; i < 3000 && !(r = inb_p (HD_STATUS) & DRQ_STAT); i++)/* nothing */ ;// 如果請求服務位置位則退出循環。若等到循環結束也沒有置位,則此次寫硬盤操作失敗,去處理// 下一個硬盤請求。否則向硬盤控制器數據寄存器端口HD_DATA 寫入1 個扇區的數據。      if (!r)	{	  bad_rw_intr ();	  goto repeat;		// 該標號在blk.h 最后面,也即跳到301 行。	}      port_write (HD_DATA, CURRENT->buffer, 256);// 如果當前請求是讀硬盤扇區,則向硬盤控制器發送讀扇區命令。    }  else if (CURRENT->cmd == READ)    {      hd_out (dev, nsect, sec, head, cyl, WIN_READ, &read_intr);    }  else    panic ("unknown hd-command");}// 硬盤系統初始化。void hd_init (void){  blk_dev[MAJOR_NR].request_fn = DEVICE_REQUEST;	// do_hd_request()。  set_intr_gate (0x2E, &hd_interrupt);	// 設置硬盤中斷門向量 int 0x2E(46)。// hd_interrupt 在(kernel/system_call.s,221)。  outb_p (inb_p (0x21) & 0xfb, 0x21);	// 復位接聯的主8259A int2 的屏蔽位,允許從片// 發出中斷請求信號。  outb (inb_p (0xA1) & 0xbf, 0xA1);	// 復位硬盤的中斷請求屏蔽位(在從片上),允許// 硬盤控制器發送中斷請求信號。}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丝袜美腿亚洲色图| 成人免费高清视频| 亚洲一级在线观看| 日韩一区在线看| 国产精品成人免费| 综合色天天鬼久久鬼色| 亚洲少妇中出一区| 一区二区三区四区蜜桃| 亚洲视频1区2区| 午夜精品爽啪视频| 久久国产精品72免费观看| 久久精品免费观看| 国产福利一区在线| 色网综合在线观看| 91精品在线一区二区| 欧美xingq一区二区| 久久丝袜美腿综合| 亚洲日本在线a| 免费国产亚洲视频| 国产69精品久久777的优势| 色成人在线视频| 911精品国产一区二区在线| 中文字幕乱码久久午夜不卡| 麻豆精品蜜桃视频网站| 国产精品素人视频| 日本一区二区综合亚洲| 中文字幕电影一区| 日日摸夜夜添夜夜添国产精品| 蜜桃视频第一区免费观看| 成人免费观看av| 欧美一区二区美女| 国产日韩欧美激情| 亚洲裸体xxx| www.欧美色图| 精品国产一区二区三区久久影院| 丁香一区二区三区| 亚洲成国产人片在线观看| 欧美tk丨vk视频| 99久久精品国产麻豆演员表| 天堂一区二区在线免费观看| 国产日产精品一区| 日韩午夜电影在线观看| 在线观看三级视频欧美| 蜜桃免费网站一区二区三区| 中文字幕乱码久久午夜不卡| 欧美三级中文字| 高清不卡在线观看| 污片在线观看一区二区| 国产精品色噜噜| 精品久久久久香蕉网| 色噜噜夜夜夜综合网| 国产精品18久久久久久久网站| 亚洲综合免费观看高清完整版| 91久久精品日日躁夜夜躁欧美| 九九久久精品视频| 婷婷夜色潮精品综合在线| 国产精品欧美经典| 国产午夜精品理论片a级大结局| 欧美日韩二区三区| 欧美亚洲免费在线一区| 亚洲国产精品一区二区尤物区| 国产午夜亚洲精品不卡| 国产片一区二区| 精品成人免费观看| 精品福利视频一区二区三区| 欧美日韩激情在线| 在线观看精品一区| 一本一道综合狠狠老| 91小视频免费观看| 色综合天天综合色综合av| 国产成人小视频| 99精品久久久久久| 久久99国内精品| 成人av午夜电影| 91免费观看视频| 欧美日韩三级视频| 欧美一区二区三区视频免费播放| 欧美日韩国产在线观看| 欧美一区二区三区免费在线看| 91精品国产综合久久久久久 | 一区二区三区高清在线| 欧美一区二区三区视频| 精品欧美一区二区在线观看| 精品久久人人做人人爽| 国产精品久久久久精k8| 亚洲一区在线观看网站| 免费在线观看精品| 成人精品视频.| 欧美区在线观看| 欧美体内she精高潮| 欧美成人精品1314www| 亚洲人一二三区| 精品中文字幕一区二区小辣椒| 免费成人在线视频观看| 成人激情图片网| 日韩欧美美女一区二区三区| 国产精品情趣视频| 日本午夜精品视频在线观看| 国产福利一区二区三区视频| 欧美系列一区二区| 欧美激情资源网| 美女www一区二区| 91久久香蕉国产日韩欧美9色| 欧美日韩一级二级| 亚洲色图第一区| 免费观看在线综合| aaa亚洲精品| 国产精品久久久久婷婷二区次| 美女看a上一区| 欧美一区二区三区在| 亚洲一区自拍偷拍| 日本二三区不卡| 亚洲欧美一区二区三区国产精品| 国产成人午夜高潮毛片| 欧美一级国产精品| 婷婷中文字幕综合| 7777精品伊人久久久大香线蕉完整版| 一区二区三区精品| 欧美亚洲丝袜传媒另类| 洋洋成人永久网站入口| 91在线免费视频观看| 日韩美女久久久| 欧美影视一区二区三区| 舔着乳尖日韩一区| 91麻豆精品国产无毒不卡在线观看| 一区二区三区波多野结衣在线观看| 不卡的av网站| 亚洲欧美国产77777| 色综合天天天天做夜夜夜夜做| 一区二区三区在线视频观看58| 国产黄色精品视频| 亚洲欧美日韩综合aⅴ视频| 91丨九色丨尤物| 青娱乐精品在线视频| 欧美精品一区二| 91香蕉视频mp4| 欧美a级一区二区| 专区另类欧美日韩| 日韩一区二区三区四区五区六区| 国产乱对白刺激视频不卡| 日韩伦理av电影| 日韩一区二区三区四区| 成人动漫一区二区在线| 一级日本不卡的影视| 精品黑人一区二区三区久久| 国产+成+人+亚洲欧洲自线| 日韩中文欧美在线| 亚洲欧洲在线观看av| 精品欧美一区二区三区精品久久| 亚洲动漫第一页| 国产精品美女一区二区在线观看| 7777精品伊人久久久大香线蕉超级流畅 | 国产精品一区二区久久精品爱涩| 国产精品久久久久久妇女6080 | 国产女主播一区| 91精品在线麻豆| 欧美日韩国产电影| 96av麻豆蜜桃一区二区| 精品无码三级在线观看视频| 婷婷一区二区三区| 日韩中文字幕一区二区三区| 亚洲欧洲av在线| 中文一区二区完整视频在线观看| 91亚洲精品久久久蜜桃| 成人视屏免费看| 国产成a人亚洲精| 粉嫩av亚洲一区二区图片| 一区二区三区在线不卡| 91精品在线一区二区| 成人av第一页| 波多野结衣精品在线| 成人av网站免费观看| eeuss鲁一区二区三区| 奇米色一区二区| 精品亚洲免费视频| 成人夜色视频网站在线观看| 激情综合色综合久久综合| 同产精品九九九| 久久99国产精品尤物| 国产aⅴ综合色| 国产在线精品一区二区不卡了| 国产福利一区二区三区视频| 99精品黄色片免费大全| 色综合中文字幕| 日韩欧美亚洲国产精品字幕久久久| 7799精品视频| 亚洲视频资源在线| 久久91精品国产91久久小草 | 欧美一级精品大片| 久久精品网站免费观看| 亚洲一区视频在线| 精品一区二区三区在线观看国产 | 久久色在线视频| 亚洲一级二级在线| 国产91精品精华液一区二区三区| 成人黄色在线视频| 欧美影院一区二区| 中文字幕欧美三区| 亚洲精品自拍动漫在线| 国产精品123区|