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

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

?? sboot.c

?? i.Mx31 bootloader(for WinCE6.0)
?? C
?? 第 1 頁 / 共 2 頁
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
//------------------------------------------------------------------------------
//
//  Copyright (C) 2007, Freescale Semiconductor, Inc. All Rights Reserved.
//  THIS SOURCE CODE, AND ITS USE AND DISTRIBUTION, IS SUBJECT TO THE TERMS
//  AND CONDITIONS OF THE APPLICABLE LICENSE AGREEMENT
//
//------------------------------------------------------------------------------
//
//  File:  sboot.c
//
//  Core routines for the Serial bootloader.
//
//-----------------------------------------------------------------------------

#include <bsp.h>
#include <loader.h>
#include <debugserial.h>

//-----------------------------------------------------------------------------
// External Functions

//-----------------------------------------------------------------------------
// External Variables
extern BSP_ARGS *g_pBSPArgs;
extern PCSP_PBC_REGS g_pPBC;
extern PCSP_IOMUX_REGS g_pIOMUX;
extern PCSP_CCM_REGS g_pCCM;
extern BOOT_CFG   g_BootCFG;
extern BOOT_BINDIO_CONTEXT g_BinDIO;

//-----------------------------------------------------------------------------
// Global Variables

static PCSP_UART_REG g_pUART;

// serial packet header and trailer definitions
static const UCHAR packetHeaderSig[] = { 'k', 'I', 'T', 'L' };

__declspec(align(4)) BYTE g_buffer[KITL_MTU];

BOOT_CFG *pBootArgs = &g_BootCFG;

//-----------------------------------------------------------------------------
// Defines
#define DEF_BAUD_RATE 115200
// DEF_BAUD_RATE must be one of 115200, 57600, 38400, 19200, 9600

// Use the serial bootloader in conjunction with the serial kitl transport
// Both the transport and the download service expect packets with the
// same header format. Packets not of type DLREQ, DLPKT, or DLACK are 
// ignored by the serial bootloader.

#define KITL_MAX_DEV_NAMELEN      16
#define KITL_MTU                  1520

#define HEADER_SIG_BYTES    sizeof(packetHeaderSig)

#define KS_PKT_KITL         0xAA
#define KS_PKT_DLREQ        0xBB
#define KS_PKT_DLPKT        0xCC
#define KS_PKT_DLACK        0xDD
#define KS_PKT_JUMP         0xEE

// serial port definitions
#define UART_UCR2_CTS_ACTIVE	0x1000
#define UART_RX_FRAMING_ERR		0x1000
#define UART_RX_PARITY_ERR		0x400
#define UART_RX_OVERRUN			0x2000
#define UART_RX_ERRORS			(UART_RX_FRAMING_ERR | UART_RX_PARITY_ERR | UART_RX_OVERRUN)

#define TIMEOUT_RECV    5 // seconds


//-----------------------------------------------------------------------------
// Types

// packet header
#include <pshpack1.h>
typedef struct tagSERIAL_PACKET_HEADER 
{
    UCHAR headerSig[HEADER_SIG_BYTES];
    UCHAR pktType;
    UCHAR Reserved;
    USHORT payloadSize; // not including this header    
    UCHAR crcData;
    UCHAR crcHdr;

} SERIAL_PACKET_HEADER, *PSERIAL_PACKET_HEADER;
#include <poppack.h>

// packet payload
typedef struct tagSERIAL_BOOT_REQUEST 
{
    UCHAR PlatformId[KITL_MAX_DEV_NAMELEN+1];
    UCHAR DeviceName[KITL_MAX_DEV_NAMELEN+1];
    USHORT reserved;

} SERIAL_BOOT_REQUEST, *PSERIAL_BOOT_REQUEST;

typedef struct tagSERIAL_BOOT_ACK
{
    DWORD fJumping;

} SERIAL_BOOT_ACK, *PSERIAL_BOOT_ACK;

typedef struct tagSERIAL_JUMP_REQUST
{
    DWORD dwKitlTransport;
    
} SERIAL_JUMP_REQUEST, *PSERIAL_JUMP_REQUEST;

typedef struct tagSERIAL_BLOCK_HEADER
{
    DWORD uBlockNum;
    
} SERIAL_BLOCK_HEADER, *PSERIAL_BLOCK_HEADER;


//-----------------------------------------------------------------------------
// Local Variables


//------------------------------------------------------------------------------
// Local Functions
//
BOOL OEMSerialSendRaw(LPBYTE pbFrame, USHORT cbFrame);
BOOL OEMSerialRecvRaw(LPBYTE pbFrame, PUSHORT pcbFrame, BOOLEAN bWaitInfinite);
BOOL RecvHeader(PSERIAL_PACKET_HEADER pHeader, BOOLEAN bWaitInfinite);
BOOL RecvPacket(PSERIAL_PACKET_HEADER pHeader, PBYTE pbFrame, PUSHORT pcbFrame, BOOLEAN bWaitInfinite);
BOOL WaitForJump(VOID);
BOOL WaitForBootAck(BOOL *pfJump);
BOOL SerialSendBlockAck(DWORD uBlockNumber);
BOOL SerialSendBootRequest(VOID);
static BOOL SBOOTReadData (DWORD cbData, LPBYTE pbData);

void ResetDefaultBootCFG(BOOT_CFG *pBootCFG);

// OS launch function type
typedef void (*PFN_LAUNCH)();

//------------------------------------------------------------------------------
//
//  Function:  OEMBootInit
//
//  Parameters:
//      None.
//
//  Returns:
//      None.
//------------------------------------------------------------------------------
void OEMBootInit (void)
{
    KITLOutputDebugString("Microsoft Windows CE Serial Bootloader %d.%d for MX32 ADS (%s %s)\r\n",
                          SBOOT_VERSION_MAJOR, SBOOT_VERSION_MINOR, __DATE__, __TIME__);

	return;
}

//------------------------------------------------------------------------------
//
//  Function:  OEMGetMagicNumber
//
//  Parameters:
//      None.
//
//  Returns:
//      Magic number of SBOOT version.
//------------------------------------------------------------------------------
UINT32 OEMGetMagicNumber()
{
	return SBOOT_CFG_MAGIC_NUMBER;
}

//------------------------------------------------------------------------------
//
//  Function:  GetPreDownloadInfo
//
//  Parameters:        
//      None.
//
//  Returns:
//      TRUE for Download/FALSE for jump to resident OS image
//------------------------------------------------------------------------------
BOOL GetPreDownloadInfo (PBOOT_CFG p_bootCfg)
{
    BOOL fGotJump = FALSE;
	BOOL bParityEnable = TRUE;
	SERIAL_INFO serInfo;
	DWORD dwParity = p_bootCfg->Parity;

    switch (p_bootCfg->Channel)
	{
		case 1:
			p_bootCfg->dwSerPhysAddr = CSP_BASE_REG_PA_UART1;
			break;

		case 2:
			p_bootCfg->dwSerPhysAddr = CSP_BASE_REG_PA_UART2;
			break;

		case 3:
			p_bootCfg->dwSerPhysAddr = CSP_BASE_REG_PA_UART3;
			break;

		case 4:
			p_bootCfg->dwSerPhysAddr = CSP_BASE_REG_PA_UART4;
			break;

		case 5:
			p_bootCfg->dwSerPhysAddr = CSP_BASE_REG_PA_UART5;
			break;

		default:
			p_bootCfg->dwSerPhysAddr = DEFAULT_SBOOT_BASE_REG;
			break;

	}

	g_pUART = (PCSP_UART_REG) OALPAtoUA(p_bootCfg->dwSerPhysAddr);
    if (g_pUART == NULL)
    {
        return FALSE;
    }

	if (p_bootCfg->Parity == SBOOT_PARITY_NONE)
	{
		bParityEnable = FALSE;
		dwParity = SBOOT_PARITY_EVEN;
	}

	serInfo.baudRate = p_bootCfg->BaudRate;
	serInfo.uartBaseAddr = p_bootCfg->dwSerPhysAddr;
	serInfo.dataBits = p_bootCfg->DataBits;
	serInfo.parity = dwParity;
	serInfo.bParityEnable = bParityEnable;
	serInfo.flowControl = p_bootCfg->FlowCtrl;
	serInfo.stopBits = p_bootCfg->StopBit;
		
    OALSerialInit(&serInfo);

    // send boot requests indefinitely
    do
    {
        EdbgOutputDebugString("Sending sboot request...\r\n");
        if(!SerialSendBootRequest())
        {
            EdbgOutputDebugString("Failed to send sboot request\r\n");
            return BL_ERROR;
        }
    }
    while(!WaitForBootAck(&fGotJump));

    // ack block zero to start the download
    SerialSendBlockAck(0);

    EdbgOutputDebugString("Received sboot request ack... starting download\r\n");

    return fGotJump  ? BL_JUMP : BL_DOWNLOAD;

}


//------------------------------------------------------------------------------
//
//  Function:  GetLaunchInfo
//
//  Parameters:        
//     None.
//
//  Returns:
//      None.
//------------------------------------------------------------------------------
void GetLaunchInfo (void)
{
    // wait for jump packet indefinitely
    if(WaitForJump() == FALSE)
    {
	    EdbgOutputDebugString("Failed to wait for jump message\r\n");
    }

    return;
}

//-----------------------------------------------------------------------------
//
//  Function:  OEMReadData
//
//  This function reads data from the transport during the download process. 
//  It is called by the BLCOMMON framework.
//
//  Parameters:
//      cbData 
//          [in] Amount of data, in bytes, to read. 
//
//      pbData 
//          [out] Pointer to read buffer. 
//
//  Returns:
//      TRUE for success/FALSE for failure.
//
//-----------------------------------------------------------------------------
BOOL OEMReadData(DWORD cbData, LPBYTE pbData)
{
	BOOL bRet = TRUE;

    // TODO: increment bytes read to track download progress.
	// Save read data size and location. It is used in workaround
	// for download BIN DIO images larger than RAM.
	g_BinDIO.readSize = cbData;
	g_BinDIO.pReadBuffer = pbData;

	bRet = SBOOTReadData(cbData, pbData);
	
	return bRet;
}


//-----------------------------------------------------------------------------
//
//  Function:  SBOOTReadData
//
//  This function reads data from the serial transport during the download. 
//
//  Parameters:
//      cbData 
//          [in] Amount of data, in bytes, to read. 
//
//      pbData 
//          [out] Pointer to read buffer. 
//
//  Returns:
//      TRUE for success/FALSE for failure.
//-----------------------------------------------------------------------------
static BOOL SBOOTReadData (DWORD cbData, LPBYTE pbData)
{
    static DWORD dwBlockNumber = 0;
    
    static USHORT cbDataBuffer = 0;    
    static BYTE dataBuffer[KITL_MTU] = {0};

    // the first DWORD in the local buffer is the block header which contains
    // the sequence number of the block received
    static PSERIAL_BLOCK_HEADER pBlockHeader = (PSERIAL_BLOCK_HEADER)dataBuffer;
    static PBYTE pBlock = dataBuffer + sizeof(PSERIAL_BLOCK_HEADER);

    SERIAL_PACKET_HEADER header;
    USHORT cbPacket;

    LPBYTE pOutBuffer = pbData;

    while(cbData)
    {
        // if there is no data in the local buffer, read some
        //
        while(0 == cbDataBuffer)
        {
             // read from port
             cbPacket = sizeof(dataBuffer);
             if(RecvPacket(&header, dataBuffer, &cbPacket, TRUE))
             {
                // ignore non-download packet types
                if(KS_PKT_DLPKT == header.pktType)
                {                    
                    // make sure we received the correct block in the sequence
                    if(dwBlockNumber == pBlockHeader->uBlockNum)
                    {
                        cbDataBuffer = header.payloadSize - sizeof(SERIAL_BLOCK_HEADER);
                        dwBlockNumber++;
                    }
                    else
                    {
                        EdbgOutputDebugString("Received out of sequence block %u\r\n", pBlockHeader->uBlockNum);
                        EdbgOutputDebugString("Expected block %u\r\n", dwBlockNumber);
                    }
                    
                    // ack, or re-ack the sender
                    if(dwBlockNumber > 0)
                    {
                        // block number has already been incremented when appropriate
                        SerialSendBlockAck(dwBlockNumber - 1);
                    }
                }
             }
        }
        
        // copy from local buffer into output buffer
        //

        // if there are more than the requested bytes, copy and shift
        // the local data buffer
        if(cbDataBuffer > cbData)
        {
            // copy requested bytes from local buffer into output buffer            
            memcpy(pOutBuffer, pBlock, cbData);
            cbDataBuffer = (USHORT)(cbDataBuffer - cbData);

            // shift the local buffer accordingly because not all data was used
            memmove(pBlock, pBlock + cbData, cbDataBuffer);
            cbData = 0;
        }
        else // cbDataBuffer <= cbData
        {
            // copy all bytes in local buffer to output buffer
            memcpy(pOutBuffer, pBlock, cbDataBuffer);
            cbData -= cbDataBuffer;
            pOutBuffer += cbDataBuffer;
            cbDataBuffer = 0;
        }
    }

    return TRUE;
}

//-----------------------------------------------------------------------------
//
//  Function:  CalcChksum
//
//  This function calculates the checksum of the serial data. 
//
//  Parameters:
//      pBuf
//          [in] Data Buffer. 
//
//      len
//          [in] Length of the buffer. 
//
//  Returns:
//      Checksum calculated
//-----------------------------------------------------------------------------
UCHAR CalcChksum(PUCHAR pBuf, USHORT len)
{
    USHORT s = 0;
    UCHAR csum = 0;

    for(s = 0; s < len; s++)
        csum = (UCHAR)(csum + (*(pBuf + s)));
    
    return csum;
}

//-----------------------------------------------------------------------------
//
//  Function:  SerialSendBootRequest
//
//  This function sends Boot requests through serial interface. 
//
//  Parameters:
//      None
//
//  Returns:
//      TRUE for success/FALSE for failure.
//-----------------------------------------------------------------------------
BOOL SerialSendBootRequest(VOID)
{
    BYTE buffer[sizeof(SERIAL_PACKET_HEADER) + sizeof(SERIAL_BOOT_REQUEST)] = {0};
    PSERIAL_PACKET_HEADER pHeader = (PSERIAL_PACKET_HEADER)buffer;
    PSERIAL_BOOT_REQUEST pBootReq = (PSERIAL_BOOT_REQUEST)(buffer + sizeof(SERIAL_PACKET_HEADER));

    // create boot request
    PREFAST_SUPPRESS(5425, "Suppressed since it requires coredll.lib which increases the image drastically");
    strcpy((CHAR *)pBootReq->PlatformId, (const CHAR *)g_pBSPArgs->deviceId);

    // create header
    memcpy(pHeader->headerSig, packetHeaderSig, HEADER_SIG_BYTES);
    pHeader->pktType = KS_PKT_DLREQ;
    pHeader->payloadSize = sizeof(SERIAL_BOOT_REQUEST);
    pHeader->crcData = CalcChksum((PBYTE)pBootReq, sizeof(SERIAL_BOOT_REQUEST));
    pHeader->crcHdr = CalcChksum((PBYTE)pHeader, 
        sizeof(SERIAL_PACKET_HEADER) - sizeof(pHeader->crcHdr));

	INSREG32BF(&g_pUART->UCR2, UART_UCR2_IRTS, UART_UCR2_IRTS_IGNORERTS);	
    OEMSerialSendRaw(buffer, sizeof(SERIAL_PACKET_HEADER) + sizeof(SERIAL_BOOT_REQUEST));
	OUTREG32(&g_pUART->UCR2, 
                INREG32(&g_pUART->UCR2)&~CSP_BITFMASK(UART_UCR2_IRTS));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡免费追剧大全电视剧网站| 国产福利一区二区三区视频| 精品久久久久久久久久久久久久久久久| 国产91露脸合集magnet| 亚洲午夜影视影院在线观看| 久久久午夜电影| 制服丝袜激情欧洲亚洲| 成人高清伦理免费影院在线观看| 免费的成人av| 亚洲综合精品久久| 国产精品欧美一级免费| 亚洲精品一区二区三区在线观看| 欧美色区777第一页| 成人午夜在线播放| 久久66热re国产| 亚洲va欧美va天堂v国产综合| 国产精品视频线看| 精品国产自在久精品国产| 91高清视频在线| 色综合久久综合网| 高清在线观看日韩| 国产在线一区二区| 麻豆久久久久久| 日韩电影免费在线观看网站| 亚洲精品高清视频在线观看| 国产精品久线在线观看| 国产午夜精品一区二区三区嫩草 | 亚洲欧美日韩电影| 久久精品一级爱片| 亚洲精品在线三区| 欧美精品一区二区三区四区| 91精品国产一区二区三区香蕉| 91国偷自产一区二区三区观看| 91免费在线看| 一本大道久久a久久综合婷婷| 成人av网站在线观看免费| 国产九色精品成人porny| 久久成人免费网| 日本不卡不码高清免费观看| 午夜成人免费视频| 性做久久久久久免费观看欧美| 亚洲国产一区二区三区| 亚洲午夜影视影院在线观看| 性久久久久久久久| 日韩中文字幕麻豆| 免费成人美女在线观看| 亚洲va欧美va人人爽| 日韩精品色哟哟| 免费精品视频在线| 国精产品一区一区三区mba桃花| 九九视频精品免费| 国产精品主播直播| 播五月开心婷婷综合| 99国产精品久久久久久久久久久| 99r国产精品| 欧美在线制服丝袜| 欧美另类高清zo欧美| 日韩视频在线永久播放| 亚洲精品在线观| 亚洲色图一区二区三区| 夜夜操天天操亚洲| 日韩不卡在线观看日韩不卡视频| 久久精品免费看| 国产精品 日产精品 欧美精品| 成人免费av在线| 91福利视频在线| 日韩午夜av电影| 国产日产欧美一区二区三区| 亚洲精品国产精品乱码不99| 五月激情六月综合| 国产老妇另类xxxxx| 91网站最新地址| 日韩一区二区精品在线观看| 国产午夜精品理论片a级大结局| 亚洲欧洲中文日韩久久av乱码| 午夜成人在线视频| 高清国产一区二区三区| 欧美在线|欧美| 久久久久久毛片| 亚洲综合精品自拍| 国产一区二区精品久久99| 色综合久久久久综合体| 日韩欧美国产1| 成人免费一区二区三区视频| 日韩激情av在线| 成人免费视频播放| 欧美一区二区视频观看视频| 国产精品久久久久婷婷二区次| 日韩精品欧美精品| 99久久综合精品| 精品少妇一区二区三区在线播放| 亚洲欧洲av一区二区三区久久| 日韩av网站在线观看| 成人av小说网| 久久天天做天天爱综合色| 一区二区在线看| 国产成人av电影在线观看| 欧美日韩一区国产| 中文字幕一区二区三区不卡在线| 麻豆精品蜜桃视频网站| 在线观看国产一区二区| 国产日韩欧美精品一区| 免费成人美女在线观看.| 91国内精品野花午夜精品| 国产亚洲欧美中文| 日韩vs国产vs欧美| 欧美视频一二三区| 日韩毛片一二三区| 国产成人免费9x9x人网站视频| 欧美美女网站色| 一区二区三区免费观看| 成人一区二区三区视频在线观看| 欧美一区三区二区| 亚洲一区二区五区| 色噜噜久久综合| 日韩伦理av电影| 成人免费电影视频| 国产欧美日韩激情| 韩国av一区二区三区四区| 欧美一区二区三区日韩| 亚洲成av人综合在线观看| 91丨九色丨黑人外教| 国产情人综合久久777777| 韩国午夜理伦三级不卡影院| 日韩一级黄色大片| 婷婷开心激情综合| 欧美色图免费看| 亚洲一线二线三线视频| 色女孩综合影院| 亚洲精品国产精品乱码不99 | 另类成人小视频在线| 欧美女孩性生活视频| 亚洲在线观看免费| 欧美三级乱人伦电影| 亚洲一区二区三区四区五区中文 | 91视视频在线观看入口直接观看www| 久久蜜桃av一区精品变态类天堂| 精品一区二区免费看| 日韩女同互慰一区二区| 欧美aⅴ一区二区三区视频| 欧美一级二级三级乱码| 免费在线观看一区二区三区| 日韩欧美国产综合一区 | 亚洲丝袜另类动漫二区| 91在线播放网址| 亚洲主播在线播放| 在线播放一区二区三区| 麻豆视频观看网址久久| 久久天天做天天爱综合色| 国产成人aaaa| 亚洲欧美另类小说| 欧美性三三影院| 日本欧美加勒比视频| 欧美大片一区二区三区| 国产精品影视网| 国产精品成人网| 欧洲生活片亚洲生活在线观看| 亚洲mv大片欧洲mv大片精品| 日韩视频在线你懂得| 国产真实乱偷精品视频免| 国产精品沙发午睡系列990531| 91网页版在线| 日韩精彩视频在线观看| 久久你懂得1024| 一本久久a久久免费精品不卡| 五月婷婷激情综合网| 精品成人免费观看| 成av人片一区二区| 亚洲sss视频在线视频| 精品国产亚洲一区二区三区在线观看| 国产91精品在线观看| 一区二区三区四区激情| 日韩欧美国产午夜精品| 99re这里只有精品首页| 视频一区中文字幕| 国产视频一区二区在线| 在线视频你懂得一区| 麻豆国产精品视频| 日韩理论片一区二区| 日韩久久精品一区| 99国产精品久久久久久久久久 | 日日夜夜免费精品| 国产女人aaa级久久久级| 在线看国产一区二区| 国产在线不卡一卡二卡三卡四卡| 亚洲少妇30p| 日韩欧美一级二级| 日本二三区不卡| 国产一区二区三区精品欧美日韩一区二区三区| 国产精品人人做人人爽人人添 | 欧美日韩日日摸| 国产精华液一区二区三区| 亚洲大片一区二区三区| 国产欧美日产一区| 精品日韩一区二区三区免费视频| 91看片淫黄大片一级| 国产精品资源在线看| 日韩电影在线观看电影| 亚洲激情男女视频| 欧美激情一区二区在线|