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

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

?? scsi-generic.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * Generic SCSI Device support * * Copyright (c) 2007 Bull S.A.S. * Based on code by Paul Brook * Based on code by Fabrice Bellard * * Written by Laurent Vivier <Laurent.Vivier@bull.net> * * This code is licenced under the LGPL. * */#include "qemu-common.h"#include "block.h"#include "scsi-disk.h"#ifndef __linux__SCSIDevice *scsi_generic_init(BlockDriverState *bdrv, int tcq,                              scsi_completionfn completion, void *opaque){    return NULL;}#else /* __linux__ *///#define DEBUG_SCSI#ifdef DEBUG_SCSI#define DPRINTF(fmt, args...) \do { printf("scsi-generic: " fmt , ##args); } while (0)#else#define DPRINTF(fmt, args...) do {} while(0)#endif#define BADF(fmt, args...) \do { fprintf(stderr, "scsi-generic: " fmt , ##args); } while (0)#include <stdio.h>#include <sys/types.h>#include <sys/stat.h>#include <unistd.h>#include <scsi/sg.h>#include <scsi/scsi.h>#define LOAD_UNLOAD 0xa6#define SET_CD_SPEED 0xbb#define BLANK 0xa1#define SCSI_CMD_BUF_SIZE     16#define SCSI_SENSE_BUF_SIZE 32#define SG_ERR_DRIVER_TIMEOUT 0x06#define SG_ERR_DRIVER_SENSE 0x08#ifndef MAX_UINT#define MAX_UINT ((unsigned int)-1)#endiftypedef struct SCSIRequest {    BlockDriverAIOCB *aiocb;    struct SCSIRequest *next;    SCSIDeviceState *dev;    uint32_t tag;    uint8_t cmd[SCSI_CMD_BUF_SIZE];    int cmdlen;    uint8_t *buf;    int buflen;    int len;    sg_io_hdr_t io_header;} SCSIRequest;struct SCSIDeviceState{    SCSIRequest *requests;    BlockDriverState *bdrv;    int blocksize;    int lun;    scsi_completionfn completion;    void *opaque;    int driver_status;    uint8_t sensebuf[SCSI_SENSE_BUF_SIZE];};/* Global pool of SCSIRequest structures.  */static SCSIRequest *free_requests = NULL;static SCSIRequest *scsi_new_request(SCSIDeviceState *s, uint32_t tag){    SCSIRequest *r;    if (free_requests) {        r = free_requests;        free_requests = r->next;    } else {        r = qemu_malloc(sizeof(SCSIRequest));        r->buf = NULL;        r->buflen = 0;    }    r->dev = s;    r->tag = tag;    memset(r->cmd, 0, sizeof(r->cmd));    memset(&r->io_header, 0, sizeof(r->io_header));    r->cmdlen = 0;    r->len = 0;    r->aiocb = NULL;    /* link */    r->next = s->requests;    s->requests = r;    return r;}static void scsi_remove_request(SCSIRequest *r){    SCSIRequest *last;    SCSIDeviceState *s = r->dev;    if (s->requests == r) {        s->requests = r->next;    } else {        last = s->requests;        while (last && last->next != r)            last = last->next;        if (last) {            last->next = r->next;        } else {            BADF("Orphaned request\n");        }    }    r->next = free_requests;    free_requests = r;}static SCSIRequest *scsi_find_request(SCSIDeviceState *s, uint32_t tag){    SCSIRequest *r;    r = s->requests;    while (r && r->tag != tag)        r = r->next;    return r;}/* Helper function for command completion.  */static void scsi_command_complete(void *opaque, int ret){    SCSIRequest *r = (SCSIRequest *)opaque;    SCSIDeviceState *s = r->dev;    uint32_t tag;    int sense;    s->driver_status = r->io_header.driver_status;    if (ret != 0)        sense = HARDWARE_ERROR;    else {        if (s->driver_status & SG_ERR_DRIVER_TIMEOUT) {            sense = HARDWARE_ERROR;            BADF("Driver Timeout\n");        } else if ((s->driver_status & SG_ERR_DRIVER_SENSE) == 0)            sense = NO_SENSE;        else            sense = s->sensebuf[2] & 0x0f;    }    DPRINTF("Command complete 0x%p tag=0x%x sense=%d\n", r, r->tag, sense);    tag = r->tag;    scsi_remove_request(r);    s->completion(s->opaque, SCSI_REASON_DONE, tag, sense);}/* Cancel a pending data transfer.  */static void scsi_cancel_io(SCSIDevice *d, uint32_t tag){    DPRINTF("scsi_cancel_io 0x%x\n", tag);    SCSIDeviceState *s = d->state;    SCSIRequest *r;    DPRINTF("Cancel tag=0x%x\n", tag);    r = scsi_find_request(s, tag);    if (r) {        if (r->aiocb)            bdrv_aio_cancel(r->aiocb);        r->aiocb = NULL;        scsi_remove_request(r);    }}static int execute_command(BlockDriverState *bdrv,                           SCSIRequest *r, int direction,			   BlockDriverCompletionFunc *complete){    r->io_header.interface_id = 'S';    r->io_header.dxfer_direction = direction;    r->io_header.dxferp = r->buf;    r->io_header.dxfer_len = r->buflen;    r->io_header.cmdp = r->cmd;    r->io_header.cmd_len = r->cmdlen;    r->io_header.mx_sb_len = sizeof(r->dev->sensebuf);    r->io_header.sbp = r->dev->sensebuf;    r->io_header.timeout = MAX_UINT;    r->io_header.usr_ptr = r;    r->io_header.flags |= SG_FLAG_DIRECT_IO;    if (bdrv_pwrite(bdrv, -1, &r->io_header, sizeof(r->io_header)) == -1) {        BADF("execute_command: write failed ! (%d)\n", errno);        return -1;    }    if (complete == NULL) {        int ret;        r->aiocb = NULL;        while ((ret = bdrv_pread(bdrv, -1, &r->io_header,                                           sizeof(r->io_header))) == -1 &&                      errno == EINTR);        if (ret == -1) {            BADF("execute_command: read failed !\n");            return -1;        }        return 0;    }    r->aiocb = bdrv_aio_read(bdrv, 0, (uint8_t*)&r->io_header,                          -(int64_t)sizeof(r->io_header), complete, r);    if (r->aiocb == NULL) {        BADF("execute_command: read failed !\n");        return -1;    }    return 0;}static void scsi_read_complete(void * opaque, int ret){    SCSIRequest *r = (SCSIRequest *)opaque;    SCSIDeviceState *s = r->dev;    int len;    if (ret) {        DPRINTF("IO error\n");        scsi_command_complete(r, ret);        return;    }    len = r->io_header.dxfer_len - r->io_header.resid;    DPRINTF("Data ready tag=0x%x len=%d\n", r->tag, len);    r->len = -1;    s->completion(s->opaque, SCSI_REASON_DATA, r->tag, len);}/* Read more data from scsi device into buffer.  */static void scsi_read_data(SCSIDevice *d, uint32_t tag){    SCSIDeviceState *s = d->state;    SCSIRequest *r;    int ret;    DPRINTF("scsi_read_data 0x%x\n", tag);    r = scsi_find_request(s, tag);    if (!r) {        BADF("Bad read tag 0x%x\n", tag);        /* ??? This is the wrong error.  */        scsi_command_complete(r, -EINVAL);        return;    }    if (r->len == -1) {        scsi_command_complete(r, 0);        return;    }    if (r->cmd[0] == REQUEST_SENSE && s->driver_status & SG_ERR_DRIVER_SENSE)    {        memcpy(r->buf, s->sensebuf, 16);        r->io_header.driver_status = 0;        r->len = -1;        s->completion(s->opaque, SCSI_REASON_DATA, r->tag, 16);        return;    }    ret = execute_command(s->bdrv, r, SG_DXFER_FROM_DEV, scsi_read_complete);    if (ret == -1) {        scsi_command_complete(r, -EINVAL);        return;    }}static void scsi_write_complete(void * opaque, int ret){    SCSIRequest *r = (SCSIRequest *)opaque;    DPRINTF("scsi_write_complete() ret = %d\n", ret);    if (ret) {        DPRINTF("IO error\n");        scsi_command_complete(r, ret);        return;    }    scsi_command_complete(r, ret);}/* Write data to a scsi device.  Returns nonzero on failure.   The transfer may complete asynchronously.  */static int scsi_write_data(SCSIDevice *d, uint32_t tag){    SCSIDeviceState *s = d->state;    SCSIRequest *r;    int ret;    DPRINTF("scsi_write_data 0x%x\n", tag);    r = scsi_find_request(s, tag);    if (!r) {        BADF("Bad write tag 0x%x\n", tag);        /* ??? This is the wrong error.  */        scsi_command_complete(r, -EINVAL);        return 0;    }    if (r->len == 0) {        r->len = r->buflen;        s->completion(s->opaque, SCSI_REASON_DATA, r->tag, r->len);        return 0;    }    ret = execute_command(s->bdrv, r, SG_DXFER_TO_DEV, scsi_write_complete);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美变态tickling挠脚心| 粉嫩欧美一区二区三区高清影视| 91视频xxxx| 成人欧美一区二区三区白人| 成+人+亚洲+综合天堂| 亚洲人成网站在线| 欧美性猛交xxxx黑人交| 午夜伊人狠狠久久| 欧美一级一区二区| 国内精品视频一区二区三区八戒| 日本一区二区综合亚洲| 色欧美日韩亚洲| 丝袜国产日韩另类美女| 日韩欧美亚洲国产精品字幕久久久| 精品一区二区三区影院在线午夜| 亚洲国产精品国自产拍av| 91麻豆精品视频| 亚洲成精国产精品女| 精品日韩99亚洲| 91首页免费视频| 蜜桃久久av一区| 国产精品久久久久久久久久久免费看 | 国产精品美女久久久久aⅴ | 欧洲精品一区二区三区在线观看| 午夜欧美在线一二页| 欧美大片一区二区| 97国产一区二区| 毛片av中文字幕一区二区| 中文字幕乱码亚洲精品一区| 欧美视频一区二区三区在线观看| 狠狠色综合色综合网络| 亚洲精品成人少妇| 26uuu精品一区二区三区四区在线| 成人精品免费网站| 日本伊人精品一区二区三区观看方式| 日韩欧美的一区| 日本精品视频一区二区三区| 久久国产精品99精品国产| 亚洲欧美日韩国产综合| 日韩欧美一二区| 91女人视频在线观看| 久久99九九99精品| 亚洲国产精品欧美一二99| 久久精品人人做人人综合| 欧美日韩国产综合久久| 成人ar影院免费观看视频| 激情综合网av| 同产精品九九九| 亚洲精品中文字幕在线观看| 26uuuu精品一区二区| 欧美精选一区二区| 在线精品视频免费播放| zzijzzij亚洲日本少妇熟睡| 激情另类小说区图片区视频区| 亚洲综合在线第一页| 国产欧美综合在线观看第十页| 欧美一区二区三区在线观看视频| 一本一本大道香蕉久在线精品| 国产精品白丝jk黑袜喷水| 欧美96一区二区免费视频| 亚洲一区在线免费观看| 亚洲精品日韩专区silk| 欧美激情在线观看视频免费| 精品久久国产字幕高潮| 日韩欧美一区在线观看| 欧美精品亚洲二区| 欧美美女激情18p| 欧美人与禽zozo性伦| 欧美色图一区二区三区| 一本大道久久a久久综合婷婷 | 日韩电影在线免费看| 亚洲一级二级在线| 一区二区三区.www| 久久99热99| 琪琪久久久久日韩精品| 日韩av网站免费在线| 日韩专区欧美专区| 日韩成人免费在线| 久久精品国产免费| 久久不见久久见免费视频7| 久久国产生活片100| 久久超碰97人人做人人爱| 国产在线播放一区三区四| 久草精品在线观看| 国产精品99久久久| 91色.com| 欧美天天综合网| 欧美一区二区三区视频在线观看| 91精品蜜臀在线一区尤物| 日韩欧美在线网站| 国产欧美精品一区二区色综合朱莉| 久久久精品天堂| 自拍视频在线观看一区二区| 一区二区在线观看视频在线观看| 亚洲国产cao| 卡一卡二国产精品| 成人免费看片app下载| 色噜噜狠狠色综合中国| 91精品欧美一区二区三区综合在 | 久久成人免费网| 国产一区不卡精品| 成人av中文字幕| 欧美美女网站色| 久久这里只精品最新地址| 国产情人综合久久777777| 亚洲精品第一国产综合野| 五月婷婷综合网| 高清不卡在线观看| 欧美日韩一区二区欧美激情| 精品国产第一区二区三区观看体验| 中文字幕第一区第二区| 亚洲香蕉伊在人在线观| 国产真实乱对白精彩久久| 91在线高清观看| 日韩一区二区精品| 中文字幕欧美区| 日本va欧美va瓶| 成人免费电影视频| 在线不卡中文字幕播放| 国产精品久久久久久久午夜片| 图片区小说区区亚洲影院| 丁香啪啪综合成人亚洲小说| 777久久久精品| 国产精品久久精品日日| 日本伊人午夜精品| 91蝌蚪porny九色| 精品久久久久久久久久久院品网 | 亚洲一卡二卡三卡四卡五卡| 国产一区二区视频在线播放| 欧美色老头old∨ideo| 国产精品女主播在线观看| 免费成人深夜小野草| 在线观看日产精品| 国产精品视频免费看| 男男视频亚洲欧美| 欧美日韩亚洲综合一区二区三区| 国产日韩欧美不卡| 免费观看日韩电影| 欧美日韩不卡一区二区| 亚洲欧美另类小说视频| 国产精品一品视频| 日韩一区二区三区免费看 | 在线一区二区三区四区五区| 久久综合999| 日韩avvvv在线播放| 欧美网站一区二区| 亚洲精品免费电影| 99久久久国产精品免费蜜臀| 久久久美女毛片| 玖玖九九国产精品| 日韩视频在线你懂得| 丝袜美腿亚洲色图| 欧美男女性生活在线直播观看| 亚洲欧美日韩精品久久久久| 成人精品国产福利| 欧美国产精品中文字幕| 国产剧情一区在线| www国产成人免费观看视频 深夜成人网| 亚洲成人免费观看| 欧美色中文字幕| 亚洲高清一区二区三区| 欧美视频在线播放| 午夜视频一区在线观看| 欧美日韩国产高清一区二区| 亚洲福利国产精品| 欧美日韩一区二区三区高清| 午夜精品久久久| 欧美一区二区播放| 久久狠狠亚洲综合| 久久综合九色综合97婷婷女人 | 极品瑜伽女神91| 久久精品视频一区二区三区| 国产露脸91国语对白| 中文字幕乱码亚洲精品一区| 成人激情黄色小说| 亚洲人成伊人成综合网小说| 在线观看日产精品| 手机精品视频在线观看| 欧美日韩久久久| 久久se精品一区二区| 国产日韩精品视频一区| 99这里只有久久精品视频| 亚洲天堂网中文字| 在线观看亚洲精品| 麻豆久久久久久久| 久久久午夜精品理论片中文字幕| 国产成人日日夜夜| 亚洲人123区| 欧美精品vⅰdeose4hd| 久久精品二区亚洲w码| 中文字幕av一区二区三区| 一本色道亚洲精品aⅴ| 日韩高清一区在线| 久久久久久一级片| 91在线精品一区二区| 亚洲成人激情自拍| 国产欧美一区二区在线观看| 91浏览器在线视频| 免费黄网站欧美| 日韩久久一区二区|