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

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

?? pehci.c

?? usb isp1761驅動源代碼 可編進內核。
?? C
?? 第 1 頁 / 共 5 頁
字號:
    u32 skipmap = 0;
    u32    newschedule = 0;
    u32 buffstatus = 0;
    u32 schedulemap = 0;
#ifndef CONFIG_ISO_SUPPORT
    u32 lasttd = 1;
#endif
    u32 lastmap = 0;
    struct urb *urb = 0;
    urb_priv_t *urbpriv = 0;    
    int length = 0;
    u32 ormask = 0,andmask = 0;
    u32 intormask = 0;
    td_ptd_map_t        *td_ptd_map;
    td_ptd_map_buff_t *ptd_map_buff;
    struct isp1761_mem_addr *mem_addr = 0;

    pehci_entry("++ %s: Entered\n",__FUNCTION__);
    pehci_print("Buffer type %d\n", bufftype);

    /*need to hold this lock if another interrupt is comming
      for previously scheduled transfer, while scheduling new tds
     */
    spin_lock(&hcd_data_lock);
    ptd_map_buff = &td_ptd_map_buff[bufftype];
    qha  = &allqha;
    switch(bufftype){
        case TD_PTD_BUFF_TYPE_ATL:
            skipmap = isp1761_reg_read32(hcd->dev, hcd->regs.atltdskipmap, skipmap);
            rmb();
            ormask = isp1761_reg_read32(hcd->dev, hcd->regs.atl_irq_mask_or, ormask);
            andmask = isp1761_reg_read32(hcd->dev, hcd->regs.atl_irq_mask_and, andmask);
            break;
        case TD_PTD_BUFF_TYPE_INTL:
            skipmap = isp1761_reg_read32(hcd->dev, hcd->regs.inttdskipmap, skipmap);
            /*read the interrupt mask registers*/
            intormask = isp1761_reg_read32(hcd->dev, hcd->regs.int_irq_mask_or,intormask);
            break;
        default:
            err("Never Error: Bogus type of bufer\n");
            return;
    }


    buffstatus = isp1761_reg_read32(hcd->dev,hcd->regs.buffer_status,buffstatus);
    /*td headers need attention*/
    schedulemap = donemap;
    while(schedulemap){
        index = schedulemap & mask;
        schedulemap &= ~mask;
        mask <<= 1;

        if(!index){
            location++;
            continue;
        }

        td_ptd_map = &ptd_map_buff->map_list[location];
        /*      can happen if donemap comes after
                removal of the urb and associated tds
         */
        if((td_ptd_map->state ==  TD_PTD_NEW) || 
                (td_ptd_map->state == TD_PTD_REMOVE)){
            qh = td_ptd_map->qh;
            pehci_check("should not come here, map %x,pending map %x\n", td_ptd_map->ptd_bitmap,
                    ptd_map_buff->pending_ptd_bitmap);

            pehci_check("buffer type %s\n", (bufftype == 0)?"ATL":"INTL");      
            donemap &= ~td_ptd_map->ptd_bitmap;
            /*clear the pending map*/
            ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;
            location++;
            continue;
        }

        /*no endpoint at this location*/
        if(!(td_ptd_map->qh)){
            err("queue head can not be null here\n");
            /*move to the next location*/
            ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;
            location++;
            continue;
        }

        /*current endpoint*/
        qh = td_ptd_map->qh;
        if(!(skipmap & td_ptd_map->ptd_bitmap)){
            /*should not happen, if happening, then*/
            pehci_check("buffertype %d,td_ptd_map %x,skipnap %x\n",
                    bufftype, td_ptd_map->ptd_bitmap,skipmap);
            lastmap = td_ptd_map->ptd_bitmap;
            donemap &= ~td_ptd_map->ptd_bitmap;
            ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;
            location++;
            continue;
        }

        /*if we processed all the tds in ths transfer*/
        if(td_ptd_map->lasttd){
            err("should not show  map %x,qtd %p\n", td_ptd_map->ptd_bitmap,td_ptd_map->qtd);
            /*this can happen in case the transfer is not being
             * procesed by the host , tho the transfer is there
             * */
            qh->hw_current = cpu_to_le32(td_ptd_map->qtd);
            ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;
            location++;
            continue;
        }

        /*if we have ptd that is going for reload*/
        if((td_ptd_map->qtd) && (td_ptd_map->state & TD_PTD_RELOAD)){
            warn("%s: reload td\n",__FUNCTION__);
            td_ptd_map->state &= ~TD_PTD_RELOAD;
            qtd = td_ptd_map->qtd;
            goto loadtd;
        }

        /* qh is there but no qtd so it means fresh transfer*/
        if((td_ptd_map->qh) && !(td_ptd_map->qtd)){
            if(list_empty(&qh->qtd_list)){
                /*should not hapen again, as it comes here
                  when it has td in its map
                 */     
                pehci_check("must not come here any more, td map %x\n",td_ptd_map->ptd_bitmap);
                /*this location is idle and can be free next time if
                  no new transfers are comming for this*/
                donemap &= ~td_ptd_map->ptd_bitmap;
                td_ptd_map->state |= TD_PTD_IDLE;
                ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;
                location++;
                continue;
            }
            qtd_list = &qh->qtd_list;
            qtd = td_ptd_map->qtd =     list_entry(qtd_list->next, struct ehci_qtd, qtd_list);
            /*got the td, now goto reload*/
            goto loadtd;
        }

        /*if there is already one qtd there in the transfer*/
        if(td_ptd_map->qtd){
            /*new schedule*/
            qtd = td_ptd_map->qtd;      
        }
loadtd:
        /*should not happen*/
        if(!qtd){
            err("this piece of code should not be executed\n");
            ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;
            location++;
            continue;
        }

        ptd_map_buff->active_ptds++;
        /*clear the pending map here*/
        ptd_map_buff->pending_ptd_bitmap &= ~td_ptd_map->ptd_bitmap;



        /*if this td is the last one*/
        if(qtd->state & QTD_STATE_LAST){
            /*no qtd anymore*/
            qh->hw_current = cpu_to_le32(0);

            /*else update the hw_next of qh to the next td*/
        }else{
            qh->hw_current = qtd->hw_next;
        }

        if(location != qh->qtd_ptd_index){
            err("Never Error: Endpoint header location and scheduling information are not same\n");
        }

        /*next location*/
        location++;
        /*found new transfer*/
        newschedule = 1;
        /*take the urb*/
        urb = qtd->urb;
        /*sometimes we miss due to skipmap
          so to make sure that we dont put again the 
          same stuff
         */
        if(!(qtd->state & QTD_STATE_NEW))
        {    
            err("Never Error: We should not put the same stuff\n");
            continue;
        }

        urbpriv = (urb_priv_t*)urb->hcpriv;
        urbpriv->timeout = 0;   

        /*no more new*/
        qtd->state &= ~QTD_STATE_NEW;
        qtd->state |= QTD_STATE_SCHEDULED;



        /*NEW, now need to get the memory for this transfer*/
        length = qtd->length;
        mem_addr = &qtd->mem_addr;
        phci_hcd_mem_alloc(length,mem_addr,0);
        if(length && (
                    (mem_addr->phy_addr == 0 )
                    || (mem_addr->virt_addr == 0))){

            err("Never Error: Can not allocate memory for the current td,length %d\n",length);
            location++;
            continue;
        }       

        pehci_check("qtd being scheduled %p, device %d,map %x\n", qtd,urb->dev->devnum,td_ptd_map->ptd_bitmap);


        memset(qha, 0, sizeof(isp1761_qha));
        /*convert qtd to qha*/
        phci_hcd_qha_from_qtd(hcd,qtd,qtd->urb, (void *)qha,
                td_ptd_map->ptd_ram_data_addr,
                qh
                /*td_ptd_map->datatoggle*/);

        if(qh->type == TD_PTD_BUFF_TYPE_INTL){
            phci_hcd_qhint_schedule(hcd, qh,qtd,(isp1761_qhint *)qha,qtd->urb);

        }


        length = PTD_XFERRED_LENGTH(qha->td_info1 >> 3);
        if(length > HC_ATL_PL_SIZE){
            err("Never Error: Bogus length,length %d(max %d)\n",(int)qtd->length, HC_ATL_PL_SIZE);
        }

        /*write qha into the header of the host controller*/
        isp1761_mem_write(hcd->dev, td_ptd_map->ptd_header_addr,0,(u32 *)(qha),PHCI_QHA_LENGTH,0);
        /*if this is SETUP/OUT token , then need to write into the buffer*/
        /*length should be valid*/
        if(qtd->length && ( length <= HC_ATL_PL_SIZE))
            switch(PTD_PID(qha->td_info2)){
                case OUT_PID:
                case SETUP_PID:
                    isp1761_mem_write(hcd->dev,(u32)mem_addr->phy_addr,0,(void*)(le32_to_cpu(qtd->hw_buf[0])),length,0);
                    break;
            }

        /*unskip the tds at this location*/
        switch(bufftype){
            case TD_PTD_BUFF_TYPE_ATL:
                skipmap &= ~td_ptd_map->ptd_bitmap;
                lastmap = td_ptd_map->ptd_bitmap;
                /*try to reduce the interrupts*/
                ormask |= td_ptd_map->ptd_bitmap;
                isp1761_reg_write32(hcd->dev, hcd->regs.atl_irq_mask_or, ormask);
                break;

            case TD_PTD_BUFF_TYPE_INTL:
                skipmap &= ~td_ptd_map->ptd_bitmap;
                lastmap = td_ptd_map->ptd_bitmap;
                intormask |= td_ptd_map->ptd_bitmap;
                isp1761_reg_write32(hcd->dev, hcd->regs.int_irq_mask_or,intormask);
                break;

            case TD_PTD_BUFF_TYPE_ISTL:
#ifdef CONFIG_ISO_SUPPORT
                iso_dbg(ISO_DBG_INFO,"Never Error: Should not come here\n");
#else
                skipmap &= ~td_ptd_map->ptd_bitmap;
                isp1761_reg_write32(hcd->dev, hcd->regs.isotdskipmap, skipmap);
                isp1761_reg_write32(hcd->dev, hcd->regs.isotdlastmap,lasttd/*td_ptd_map->ptd_bitmap*/);
#endif /* CONFIG_ISO_SUPPORT */
                break;
        }


    }
    /*if any new schedule, enable the atl buffer*/

    if(newschedule){
        switch(bufftype){
            case TD_PTD_BUFF_TYPE_ATL:
                isp1761_reg_write32(hcd->dev, hcd->regs.buffer_status, buffstatus | ATL_BUFFER);
                /*i am comming here to only those tds that has to be scheduled*/
                /*so skip map must be in place*/
                if(skipmap & donemap){
                    pehci_check("must be both ones compliment of each other\n");
                    pehci_check("problem, skipmap %x, donemap %x,\n",skipmap,donemap);

                }
                skipmap &= ~donemap;
                isp1761_reg_write32(hcd->dev, hcd->regs.atltdskipmap, skipmap);

                break;
            case TD_PTD_BUFF_TYPE_INTL:
                isp1761_reg_write32(hcd->dev, hcd->regs.buffer_status, buffstatus | INT_BUFFER);
                skipmap &= ~donemap;
                isp1761_reg_write32(hcd->dev, hcd->regs.inttdskipmap, skipmap);
                break;
            case TD_PTD_BUFF_TYPE_ISTL:
#ifndef CONFIG_ISO_SUPPORT
                isp1761_reg_write32(hcd->dev, hcd->regs.buffer_status, buffstatus | ISO_BUFFER);
#endif
                break;
        }
    }
    spin_unlock(&hcd_data_lock);
    pehci_entry("-- %s: Exit\n",__FUNCTION__);
}

static void
pehci_hcd_qtd_schedule(phci_hcd *hcd,struct ehci_qtd *qtd,
        struct ehci_qh *qh,td_ptd_map_t *td_ptd_map)
{

    struct urb *urb;
    urb_priv_t *urbpriv  = 0;
    u32 length;
    struct isp1761_mem_addr *mem_addr = 0;
    struct _isp1761_qha *qha, qhtemp;

    pehci_entry("++ %s: Entered\n",__FUNCTION__);

    /*redundant*/
    qha = &qhtemp;

    /*if this td is the last one*/
    if(qtd->state & QTD_STATE_LAST){
        /*no qtd anymore*/
        qh->hw_current = cpu_to_le32(0);

        /*else update the hw_next of qh to the next td*/
    }else{
        qh->hw_current = qtd->hw_next;
    }

    urb = qtd->urb;
    urbpriv = (urb_priv_t*)urb->hcpriv;
    urbpriv->timeout = 0;       

    /*NEW, now need to get the memory for this transfer*/
    length = qtd->length;
    mem_addr = &qtd->mem_addr;
    phci_hcd_mem_alloc(length,mem_addr,0);
    if(length && (
                (mem_addr->phy_addr == 0 )
                || (mem_addr->virt_addr == 0))){
        err("Never Error: Cannot allocate memory for the current td,length %d\n",length);
        return;
    }   

    pehci_check("newqtd being scheduled, device: %d,map: %x\n", urb->dev->devnum,td_ptd_map->ptd_bitmap);

    memset(qha, 0, sizeof(isp1761_qha));
    /*convert qtd to qha*/
    phci_hcd_qha_from_qtd(hcd,qtd,qtd->urb, (void *)qha,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩在线观看一区二区| 成人毛片在线观看| 日韩一区二区免费在线观看| 婷婷激情综合网| 日韩一区二区三区免费看| 久久91精品国产91久久小草| 久久麻豆一区二区| 99r国产精品| 亚洲www啪成人一区二区麻豆| 欧美久久久久久蜜桃| 国内一区二区视频| 亚洲欧洲色图综合| 8v天堂国产在线一区二区| 日本中文一区二区三区| 国产欧美日韩激情| 日本精品视频一区二区| 日韩精品一二三四| 日本一区二区三区国色天香| 色狠狠一区二区| 琪琪久久久久日韩精品| 国产精品素人一区二区| 在线一区二区视频| 国产一区不卡在线| 一区二区三区成人| 日韩欧美专区在线| 99精品在线免费| 日日欢夜夜爽一区| 国产精品久久网站| 5566中文字幕一区二区电影| 国产91精品一区二区麻豆网站| 一区二区高清在线| 久久人人爽爽爽人久久久| 色网站国产精品| 九九精品一区二区| 夜夜爽夜夜爽精品视频| 国产视频一区二区三区在线观看 | 国产欧美日韩在线看| 欧美色图在线观看| 成人永久看片免费视频天堂| 香蕉影视欧美成人| 亚洲天堂2016| 久久伊人中文字幕| 777久久久精品| 99视频超级精品| 国产一区欧美日韩| 日本亚洲免费观看| 亚洲国产日韩一区二区| 国产精品久久久久桃色tv| 精品国精品自拍自在线| 欧美日韩视频第一区| 99久久国产免费看| 成人综合婷婷国产精品久久蜜臀 | 国产精品一线二线三线精华| 亚洲国产日日夜夜| 亚洲人成网站色在线观看| 精品1区2区在线观看| 欧美老肥妇做.爰bbww| 91捆绑美女网站| 成人在线视频首页| 国产一区二区三区视频在线播放| 丝袜脚交一区二区| 一区二区三区日韩在线观看| 国产精品久久久久久户外露出 | 顶级嫩模精品视频在线看| 日本在线不卡一区| 午夜精品久久久久久不卡8050| 亚洲人成网站在线| 亚洲视频中文字幕| 亚洲欧美日韩国产综合| 国产精品嫩草99a| 国产精品乱码妇女bbbb| 久久久精品影视| 久久亚洲一区二区三区明星换脸| 欧美tk—视频vk| 精品不卡在线视频| 国产日韩欧美电影| 国产精品欧美综合在线| 中文字幕日本乱码精品影院| 成人免费小视频| 一区二区三区色| 亚洲成a人片综合在线| 日韩精彩视频在线观看| 日本不卡免费在线视频| 久久国产免费看| 国产精品一区一区三区| 国产999精品久久久久久| 国产99久久精品| 91免费看视频| 欧美日韩在线精品一区二区三区激情 | 国产精品久久久久久久午夜片| 国产精品全国免费观看高清| 亚洲女与黑人做爰| 亚洲午夜羞羞片| 免费观看久久久4p| 久久av中文字幕片| 成人精品视频一区| 色欧美乱欧美15图片| 欧美日产国产精品| 精品88久久久久88久久久| 国产精品免费视频观看| 亚洲一区二区三区四区在线免费观看| 亚洲va欧美va人人爽午夜| 青青草精品视频| 丰满放荡岳乱妇91ww| 94-欧美-setu| 欧美一区二区在线免费播放 | 国产69精品久久99不卡| 日本国产一区二区| 精品国产一区二区三区久久影院| 欧美激情一区二区| 亚洲一区二区三区影院| 久久精工是国产品牌吗| 成人av在线一区二区| 欧美日韩国产精选| 国产蜜臀av在线一区二区三区| 亚洲影院理伦片| 国产精品一区二区久久不卡| 在线区一区二视频| 久久亚洲精精品中文字幕早川悠里 | 欧美精品一区二区三区高清aⅴ | 91网站最新地址| 欧美亚州韩日在线看免费版国语版| 日韩视频一区在线观看| 中文字幕乱码亚洲精品一区| 亚洲国产另类av| 国产成人aaaa| 欧美高清精品3d| 亚洲国产高清不卡| 美女视频一区二区| 欧美在线一二三| 国产欧美日韩激情| 蜜桃av一区二区在线观看| 日本韩国精品在线| 亚洲国产精品成人综合色在线婷婷 | 91精品国产色综合久久久蜜香臀| 欧美日韩一区二区三区四区| 日本一区二区不卡视频| 国产99久久久久| 精品视频在线免费| 国产欧美日韩精品在线| 麻豆一区二区99久久久久| 一本一道久久a久久精品| 国产日韩欧美精品一区| 老司机免费视频一区二区三区| 97超碰欧美中文字幕| 国产亚洲精品超碰| 麻豆精品视频在线观看免费| 欧美日韩成人综合| 亚洲地区一二三色| 色天天综合久久久久综合片| 中文一区二区在线观看| 国产九色精品成人porny| 日韩一本二本av| 日韩国产欧美在线视频| 欧美在线视频全部完| 一个色综合网站| 欧美在线观看视频在线| 亚洲日穴在线视频| 91丨porny丨蝌蚪视频| 国产精品久久久久久一区二区三区| 国产高清久久久久| 国产区在线观看成人精品| 国产福利一区二区三区| 久久久久久久久久美女| 国产黄色精品网站| 国产精品久久久久久久午夜片| 国产成人一级电影| 国产精品污www在线观看| 成人小视频在线| 国产精品色一区二区三区| av一二三不卡影片| 亚洲色图欧洲色图婷婷| 在线视频观看一区| 午夜视黄欧洲亚洲| 欧美一区二区视频观看视频| 久久精品国产在热久久| www国产精品av| 成人精品免费视频| 亚洲免费在线电影| 欧美性大战久久久| 男女性色大片免费观看一区二区 | 色老汉一区二区三区| 亚洲精品五月天| 成人欧美一区二区三区黑人麻豆| www.亚洲人| 亚洲免费成人av| 这里只有精品免费| 国内精品写真在线观看| 亚洲国产精品ⅴa在线观看| 91麻豆产精品久久久久久| 亚洲国产日韩在线一区模特| 91精品国产麻豆国产自产在线| 美女一区二区三区在线观看| 久久精品视频在线免费观看| 成人午夜视频在线| 亚洲国产视频一区二区| 精品国产3级a| 99久久精品费精品国产一区二区| 处破女av一区二区| 亚洲成人久久影院|