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

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

?? gspi_bus_2440.c

?? murata wifi 模塊源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
        g_pHwInfo->dmaRxBuf[19]
        ));
    //*/

    prepare_for_spibus(data, g_pHwInfo->dmaRxBuf + 2, size);

    GspiBusReleaseIO();

	return GSPI_OK;
}

int gspi_read_data(UINT16 *data, UINT16 size)
{
   
	GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
	GspiBusSetTransmitter_nodma();

	gspi_write_for_read(data[0], 1 + g_spi_dummy_clk_reg); 
	

	GspiBusResetTransmitter();
	GspiBusSetReceiver();
	GspiBusStartRxDMA(0, size * 2 + 2);
	GspiBusWaitForRxDMA();
	GSPI_WAIT_FOR_BUS_RDY();

//	GspiHostSetSCSHigh();
	GspiBusResetReceiver();

//	if (((volatile)(g_pHwInfo->pSPIRegs->rSPSTA0) & BIT0))
    { // read the last byte
        g_pHwInfo->dmaRxBuf[size * 2] = g_pHwInfo->pSPIRegs->rSPRDAT0 & 0xff;
    }

    /*
    DBG_PRINT(gDbgInfo,("rbuffer: %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x %02x\n", 
        g_pHwInfo->dmaRxBuf[0], 
        g_pHwInfo->dmaRxBuf[1], 
        g_pHwInfo->dmaRxBuf[2], 
        g_pHwInfo->dmaRxBuf[3],
        g_pHwInfo->dmaRxBuf[4],
        g_pHwInfo->dmaRxBuf[5],
        g_pHwInfo->dmaRxBuf[6],
        g_pHwInfo->dmaRxBuf[7],
        g_pHwInfo->dmaRxBuf[8],
        g_pHwInfo->dmaRxBuf[9],
        g_pHwInfo->dmaRxBuf[10],
        g_pHwInfo->dmaRxBuf[11],
        g_pHwInfo->dmaRxBuf[12],
        g_pHwInfo->dmaRxBuf[13],
        g_pHwInfo->dmaRxBuf[14],
        g_pHwInfo->dmaRxBuf[15],
        g_pHwInfo->dmaRxBuf[16],
        g_pHwInfo->dmaRxBuf[17],
        g_pHwInfo->dmaRxBuf[18],
        g_pHwInfo->dmaRxBuf[19]
        ));
    //*/

	
    // endian swap
    prepare_for_spibus((UINT8 *)data, g_pHwInfo->dmaRxBuf + 2, size);

    GspiBusReleaseIO();

	return GSPI_OK;
}


int gspi_bus_write_data(UINT16 *data, UINT16 size)
{

    UINT16 sizeInBytes = size << 1;
		
    GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
	GspiBusSetTransmitter();

    data[0] |= BYTE_STREAM(GSPI_WRITE);
    //DBG_PRINT(gDbgInfo,("buffer: %02x %02x %02x %02x\n", pData[0], pData[1], pData[2], pData[3]));


 
    prepare_for_spibus((unsigned char *)g_pHwInfo->dmaTxBuf, (UCHAR*)data, size);
    // endian swap
    /*
    DBG_PRINT(gDbgInfo,("%02x %02x %02x %02x %02x %02x %02x %02x\n", 
        g_pHwInfo->dmaTxBuf[0],
        g_pHwInfo->dmaTxBuf[1],
        g_pHwInfo->dmaTxBuf[2],
        g_pHwInfo->dmaTxBuf[3],
        g_pHwInfo->dmaTxBuf[4],
        g_pHwInfo->dmaTxBuf[5],
        g_pHwInfo->dmaTxBuf[6],
        g_pHwInfo->dmaTxBuf[7]
        ));
    //*/
	GspiBusStartTxDMA(0, size * 2);	
	GspiBusWaitForTxDMA();
	GSPI_WAIT_FOR_BUS_RDY();
//	while (!((volatile)(g_pHwInfo->pSPIRegs->rSPSTA0) & BIT0));
//	GSPI_WAIT_FOR_BUS_RDY(); 
//	gspi_delay(10);	

	GspiBusResetTransmitter();
//	GspiHostSetSCSHigh();
    GspiBusReleaseIO();
	
	return GSPI_OK;
}

int gspi_bus_write_data_direct(UCHAR *data, UINT16 reg, UINT16 size)
{

    GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
	GspiBusSetTransmitter();

	reg |= BYTE_STREAM(GSPI_WRITE);

   // endian swap
	prepare_for_spibus(g_pHwInfo->dmaTxBuf, (UCHAR*)&reg,  1);
    prepare_for_spibus(g_pHwInfo->dmaTxBuf + 2, data,  (size-1));
    /*
    DBG_PRINT(gDbgInfo,("%02x %02x %02x %02x %02x %02x %02x %02x\n", 
        g_pHwInfo->dmaTxBuf[0],
        g_pHwInfo->dmaTxBuf[1],
        g_pHwInfo->dmaTxBuf[2],
        g_pHwInfo->dmaTxBuf[3],
        g_pHwInfo->dmaTxBuf[4],
        g_pHwInfo->dmaTxBuf[5],
        g_pHwInfo->dmaTxBuf[6],
        g_pHwInfo->dmaTxBuf[7]
        ));
    //*/
	GspiBusStartTxDMA(0, size * 2);

	GspiBusWaitForTxDMA();
	GSPI_WAIT_FOR_BUS_RDY();
	//gspi_delay(20);	

	GspiBusResetTransmitter();
//	GspiHostSetSCSHigh();
    GspiBusReleaseIO();
	return GSPI_OK;
}
/*--------------------------------------------------*/

int gspi_read_data_direct_nodma(UCHAR *data, UINT16 reg, UINT16 size)
{
  
	UINT8 dummy = 0xff;

 	GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
    GspiBusSetTransmitter_nodma();

	gspi_write_for_read(reg, 1 + g_spi_dummy_clk_data); 
    gspi_recv_data((UINT16*)data,size);
//	gspi_delay(500);
//	GspiHostSetSCSHigh();
	GspiBusResetReceiver();

    GspiBusReleaseIO();

	return GSPI_OK;
}

int gspi_read_data_nodma(UINT16 *data, UINT16 size)
{
   	GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
	GspiBusSetTransmitter_nodma();

	gspi_write_for_read(data[0], 1 + g_spi_dummy_clk_reg); 	
    gspi_recv_data((UINT16*)data,size);
//	gspi_delay(500);   
//	GspiHostSetSCSHigh();
	GspiBusResetReceiver();
    GspiBusReleaseIO();

    return GSPI_OK;
}


int gspi_write_data_nodma(UINT16 *data, UINT16 size)
{

  	GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
	GspiBusSetTransmitter_nodma();

    data[0] |= BYTE_STREAM(GSPI_WRITE);
    //DBG_PRINT(gDbgInfo,("buffer: %02x %02x %02x %02x\n", pData[0], pData[1], pData[2], pData[3]));

	gspi_xmt_data(data,size);
//	gspi_delay(500);	
	//GSPI_WAIT_FOR_BUS_RDY();

	GspiBusResetTransmitter();
//	GspiHostSetSCSHigh();
    GspiBusReleaseIO();
   	
	return GSPI_OK;
}

int gspi_write_data_direct_nodma(UCHAR *data, UINT16 reg, UINT16 size)
{
	
    GspiBusAcquireIO();
	GspiHostSetSCSHigh();
	GspiHostSetSCSLow();
	GspiBusSetTransmitter_nodma();

	reg |= BYTE_STREAM(GSPI_WRITE);

  	gspi_xmt_data((UINT16*)&reg,1);   
	gspi_xmt_data((UINT16*)data, size);
//	gspi_delay(500);	
//	GSPI_WAIT_FOR_BUS_RDY();

 	GspiBusResetTransmitter();
//	GspiHostSetSCSHigh();

    GspiBusReleaseIO();
	
	return GSPI_OK;
}
/*-------------------------*/

BOOL VirtualCopy( 
  LPVOID lpvDest, 
  LPVOID lpvSrc, 
  DWORD cbSize, 
  DWORD fdwProtect 
);

unsigned long GspiBusGetBSPIntID()
{
    return SYSINTR_WLAN;
}
unsigned long GspiBusGetBSPDMAIntID()
{
    return SYSINTR_DMA1;
}

//
// Map a physical region of memory to a virtual region of memory
//
void* MapIOSpace(void* pPhysAddr,
                 DWORD dwSize,
                 DWORD dwFlags) // PAGE_READONLY, PAGE_READWRITE, PAGE_NOCACHE
{

  void*       pPhysBase;
  DWORD       dwOffset;
  void*       pVirtBase;
  void*       pVirtAddr = NULL;

  /*** Everything must be aligned on page boundaries ***/

  // Determine the system page size (only once)
  if(!si.dwPageSize)
  {
    GetSystemInfo(&si);
  }

  // Determine how much beyond a page boundary the requested memory is
  dwOffset = (DWORD)pPhysAddr % si.dwPageSize;

  // Get the nearest page boundary
  pPhysBase = (void*)((DWORD)pPhysAddr - dwOffset);
  
  // If the requested address is not page aligned, adjust the size
  dwSize += dwOffset;
  
  // Adjust the size to a multiple of pages
  dwSize = dwSize + si.dwPageSize - 1;
  dwSize -= dwSize % si.dwPageSize;

  // Allocate some virtual memory
  pVirtBase = VirtualAlloc(NULL,
                           dwSize,
                           MEM_RESERVE,
                           PAGE_NOACCESS);
  if(pVirtBase)
  {
    // If the starting physical address is <= 512MB, we must divide it by
    //  256 and set the PAGE_PHYSICAL bit to make VirtualCopy() happy.  This
    //  is exactly the opposite of the documentation...
//#ifndef BUILT_FOR_WCE500
//    if((DWORD)pPhysBase < 0x20000000)
//#endif
    {
      pPhysBase = (void*)((DWORD)pPhysBase / 256);
      dwFlags |= PAGE_PHYSICAL;
    }

    // Map the physical memory into the virtual memory
    if(!VirtualCopy(pVirtBase,
                    pPhysBase,
                    dwSize,
                    dwFlags))
    {
      VirtualFree(pVirtBase, 0, MEM_RELEASE);
    }
    else
    {
      pVirtAddr = (void*)((DWORD)pVirtBase + dwOffset);
    }
  }

  return(pVirtAddr);
}

void UnmapIOSpace(void* pVirtAddr)
{
  DWORD       dwOffset;
  void*       pVirtBase;

  // Determine how much beyond a page boundary the requested memory is
  dwOffset = (DWORD)pVirtAddr % si.dwPageSize;

  // Get the nearest page boundary
  pVirtBase = (void*)((DWORD)pVirtAddr - dwOffset);

  // Release the virtual pointer
  VirtualFree(pVirtBase, 0, MEM_RELEASE);

}
int gspi_delay_loop; 
void gspi_delay(int loop)
{	
	int i;
	for (i = 0; i < loop; i++)
			gspi_delay_loop=loop;
}
//gli wake up config  這個函數主要是用來把中斷的pin配置成wakeupsource功能用
VOID gspx_config_wakeup(PVOID pHD)
{
	DWORD ttt;

	GSPIMSG(1, (TEXT("GSPI: gspx_config_wakeup\r\n")));
#if 0

	// Configure the interrupt pin
    g_pHwInfo->pGPIORegs->rGPGCON &= ~(3<<8);
    g_pHwInfo->pGPIORegs->rGPGCON |= (2<<8);
    g_pHwInfo->pGPIORegs->rGPGUP  |= (1<<4);

	ttt = (g_pHwInfo->pGPIORegs->rEXTINT1 & (~(0xf<<16))) | (0x2<<16);
	g_pHwInfo->pGPIORegs->rEXTINT1 = ttt;
#endif 
	return GSPI_OK;	
}

// gli this function will be called  for wake up so need not power up and reset module
//這個函數主要實現當cpu被wakeup起來后要重新對gpio口進行配置特別是被配置成wakeup source功能的pin 重新配置成中斷功能,和初始化配置一樣。千萬不要進行powerdown的超作
VOID gspx_reinit_hw(PVOID pHC)
{
	DWORD ttt;

	GSPIMSG(1, (TEXT("GSPI: gspx_reinit_hw\r\n")));

	g_pHwInfo->pGPIORegs->rGPGCON &= ~((0x03 << 10) | (0x03 << 12) | (0x03 << 14)); // clear
    g_pHwInfo->pGPIORegs->rGPGCON |= (0x03 << 10) | (0x03 << 12) | (0x03 << 14);	// set
	g_pHwInfo->pGPIORegs->rGPGUP |= (0x01 << 5)|(0x01 << 6);

	// to config SPI_CS:GPE11 as general io pin
	g_pHwInfo->pGPIORegs->rGPECON &= ~(0x03 << 22); // clear 
	g_pHwInfo->pGPIORegs->rGPECON |= 0x01 << 22;	// set
	g_pHwInfo->pGPIORegs->rGPEUP |= (0x01 << 11);

	//Reset:GPG12 as output
	//g_pHwInfo->pGPIORegs->rGPGCON &= ~(0x03 << 24); // clear 
	//g_pHwInfo->pGPIORegs->rGPGCON |= 0x01 << 24;	// set
	//g_pHwInfo->pGPIORegs->rGPGUP |= (0x01 << 12);
	
	//PowerDown:GPA12 as output
	g_pHwInfo->pGPIORegs->rGPACON &= ~(0x01 << 12); // set GPA12 to 0 

	// Configure the interrupt pin
    g_pHwInfo->pGPIORegs->rGPGCON &= ~(3<<8);
    g_pHwInfo->pGPIORegs->rGPGCON |= (2<<8);
    g_pHwInfo->pGPIORegs->rGPGUP  |= (1<<4);

	ttt = (g_pHwInfo->pGPIORegs->rEXTINT1 & (~(0xf<<16))) | (0x2<<16);
	g_pHwInfo->pGPIORegs->rEXTINT1 = ttt;

	//GspiHostSetRSTHigh();
	//GspiHostSetPDHigh();
	//GspiHostSetSCSHigh();

}

//這個函數主要是對gpio重新進行初始化,不過你可以需要對模塊進行一個powerdown and reset module的動作,就在你昨天那個問題點擊power按鈕系統再次起來 scan不到ap的愿意可能是你們需要對gpio口在次進行一次初始化動作
VOID gspx_reinit(PVOID pHC)
{
	DWORD ttt;

	GSPIMSG(1, (TEXT("GSPI: gspx_reinit\r\n")));

	g_pHwInfo->pGPIORegs->rGPGCON &= ~((0x03 << 10) | (0x03 << 12) | (0x03 << 14)); // clear
    g_pHwInfo->pGPIORegs->rGPGCON |= (0x03 << 10) | (0x03 << 12) | (0x03 << 14);	// set
	g_pHwInfo->pGPIORegs->rGPGUP |= (0x01 << 5)|(0x01 << 6);

	// to config SPI_CS:GPE11 as general io pin
	g_pHwInfo->pGPIORegs->rGPECON &= ~(0x03 << 22); // clear 
	g_pHwInfo->pGPIORegs->rGPECON |= 0x01 << 22;	// set
	g_pHwInfo->pGPIORegs->rGPEUP |= (0x01 << 11);

	//Reset:GPG12 as output
	//g_pHwInfo->pGPIORegs->rGPGCON &= ~(0x03 << 24); // clear 
	//g_pHwInfo->pGPIORegs->rGPGCON |= 0x01 << 24;	// set
	//g_pHwInfo->pGPIORegs->rGPGUP |= (0x01 << 12);
	
	//PowerDown:GPA12 as output
	g_pHwInfo->pGPIORegs->rGPACON &= ~(0x01 << 12); // set GPA12 to 0 

	// Configure the interrupt pin
    g_pHwInfo->pGPIORegs->rGPGCON &= ~(3<<8);
    g_pHwInfo->pGPIORegs->rGPGCON |= (2<<8);
    g_pHwInfo->pGPIORegs->rGPGUP  |= (1<<4);

	ttt = (g_pHwInfo->pGPIORegs->rEXTINT1 & (~(0xf<<16))) | (0x2<<16);
	g_pHwInfo->pGPIORegs->rEXTINT1 = ttt;

    // take the card out of reset
	GspiHostSetRSTHigh();
	//NdisMSleep(1000);
	Sleep(1);
	GspiHostSetRSTLow();

	Sleep(10);
   	GspiHostSetRSTHigh();
	GspiHostSetPDHigh();
	GspiHostSetSCSHigh();

	Sleep(1);

}

#endif 

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产在线一区二区| 蜜臀久久99精品久久久久久9| 福利电影一区二区| 国产三级精品视频| 成人免费视频视频| 亚洲免费在线视频一区 二区| 91福利国产成人精品照片| 国产一区二三区| 国产偷v国产偷v亚洲高清| 不卡av在线免费观看| 亚洲美女屁股眼交3| 91精品国产免费久久综合| 久久国产福利国产秒拍| 国产人伦精品一区二区| 91啪亚洲精品| 亚洲电影在线播放| 精品久久免费看| av在线播放成人| 亚洲成va人在线观看| 2023国产精品| av不卡在线播放| 日韩精品久久理论片| 国产午夜亚洲精品羞羞网站| 日本高清免费不卡视频| 免费在线观看日韩欧美| 国产精品盗摄一区二区三区| 欧美日本视频在线| 高清av一区二区| 亚洲成人精品一区二区| 国产校园另类小说区| 欧美日韩久久久| 成人国产电影网| 日韩福利视频导航| 国产精品免费人成网站| 日韩一区二区三区三四区视频在线观看 | 精品不卡在线视频| 99久久精品情趣| 不卡的av电影| 韩国中文字幕2020精品| 亚洲国产精品视频| 中文字幕av资源一区| 欧美一区二区免费| 91麻豆成人久久精品二区三区| 久久国产三级精品| 亚洲成av人片在www色猫咪| 国产精品丝袜在线| wwwwww.欧美系列| 777xxx欧美| 91国偷自产一区二区使用方法| 国产iv一区二区三区| 蜜臀精品一区二区三区在线观看| 亚洲黄色av一区| 亚洲国产精品国自产拍av| 欧美成人三级在线| 欧美一级免费大片| 欧美日韩在线观看一区二区| 99国产精品一区| www.激情成人| 波波电影院一区二区三区| 国内精品久久久久影院一蜜桃| 天天综合网天天综合色| 亚洲自拍偷拍麻豆| 亚洲欧美国产77777| 亚洲欧洲日产国码二区| 国产三级三级三级精品8ⅰ区| 精品国产凹凸成av人导航| 欧美一区二区三级| 日韩三级视频中文字幕| 欧美一区二区在线免费观看| 欧美丰满嫩嫩电影| 欧美日韩免费电影| 欧美精品一二三| 91麻豆精品国产91久久久更新时间 | 欧美成人video| 日韩你懂的电影在线观看| 91麻豆精品国产综合久久久久久| 69堂精品视频| 精品美女被调教视频大全网站| 欧美一区二区国产| 欧美大肚乱孕交hd孕妇| 日韩一区二区免费在线观看| 精品日韩av一区二区| 久久精品亚洲精品国产欧美kt∨| 久久久久久**毛片大全| 欧美激情自拍偷拍| 亚洲欧美在线视频观看| 日韩精品91亚洲二区在线观看| 丝袜美腿亚洲综合| 精品一区二区三区免费观看| 国产伦精品一区二区三区免费迷| 国产91精品精华液一区二区三区 | 日韩欧美一区二区免费| 精品99999| 国产精品女上位| 亚洲综合一区二区三区| 亚洲一区二区三区视频在线播放| 亚洲第一会所有码转帖| 久久99精品一区二区三区三区| 国产精品91xxx| 色综合色综合色综合色综合色综合| 欧美色爱综合网| 精品久久久久久久久久久院品网| 国产欧美一区二区精品忘忧草| 亚洲欧美偷拍另类a∨色屁股| 亚洲国产精品一区二区尤物区| 蜜臀99久久精品久久久久久软件| 激情伊人五月天久久综合| www.欧美.com| 欧美一区二区三区爱爱| 国产精品电影一区二区三区| 午夜精品福利一区二区三区蜜桃| 国产一区二区三区精品视频| 99久久精品国产麻豆演员表| 欧美疯狂性受xxxxx喷水图片| 亚洲国产成人午夜在线一区| 天天色综合天天| 高清不卡在线观看| 91精品国产色综合久久| 国产精品久久久久婷婷| 免费国产亚洲视频| eeuss鲁片一区二区三区在线看| 欧美精品丝袜久久久中文字幕| 国产女主播视频一区二区| 午夜电影久久久| 成+人+亚洲+综合天堂| 日韩欧美一区二区在线视频| 自拍偷拍亚洲欧美日韩| 久久丁香综合五月国产三级网站| 色久综合一二码| 国产欧美日韩在线看| 肉色丝袜一区二区| 色就色 综合激情| 国产亚洲欧美激情| 青娱乐精品视频| 欧美日韩综合在线免费观看| 国产午夜亚洲精品理论片色戒| 日韩avvvv在线播放| 91国产精品成人| 亚洲国产成人私人影院tom| 美女视频一区在线观看| 欧美人体做爰大胆视频| 国产精品福利一区二区| 国产一区二区视频在线| 欧美一级搡bbbb搡bbbb| 亚洲第一主播视频| 在线亚洲一区二区| 中文字幕中文字幕在线一区 | 亚洲品质自拍视频| 国产91对白在线观看九色| 日韩三级av在线播放| 视频在线观看91| 欧美性欧美巨大黑白大战| 亚洲欧美国产高清| 91丝袜国产在线播放| 国产精品视频观看| 91精品国产美女浴室洗澡无遮挡| 亚洲精品久久嫩草网站秘色| 成年人国产精品| 国产精品麻豆久久久| 懂色av一区二区三区蜜臀| 久久九九全国免费| 国产综合一区二区| 久久久综合网站| 国产麻豆精品theporn| 久久精品夜色噜噜亚洲aⅴ| 国产一区二区三区四| 国产欧美日韩麻豆91| 丁香亚洲综合激情啪啪综合| 久久久精品人体av艺术| 国产精品一区一区| 亚洲国产激情av| 不卡av在线网| 亚洲色图欧洲色图| 欧美这里有精品| 亚洲成人自拍一区| 7777精品伊人久久久大香线蕉完整版 | 国产三级一区二区三区| 国产·精品毛片| 亚洲欧美乱综合| 欧美美女一区二区三区| 美女视频免费一区| 国产亚洲欧美色| 一本色道综合亚洲| 亚洲自拍偷拍九九九| 911精品国产一区二区在线| 青娱乐精品视频| 国产女人aaa级久久久级| av一区二区三区| 亚洲一区在线观看免费观看电影高清 | 欧美亚洲尤物久久| 亚洲大尺度视频在线观看| 日韩欧美综合一区| 成人av网站在线观看| 亚洲成人在线网站| 久久综合九色综合97婷婷女人| av不卡在线播放| 日韩av电影一区| 欧美经典一区二区三区| 91电影在线观看| 国产在线视频不卡二|