亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
自拍偷拍欧美精品| 午夜精品久久一牛影视| 丁香一区二区三区| 久久精品在线观看| 成人亚洲一区二区一| 亚洲人成小说网站色在线| 99精品在线免费| 一区二区三区 在线观看视频| 欧美视频完全免费看| 丝袜亚洲另类丝袜在线| 日韩免费看的电影| 高清久久久久久| 亚洲另类色综合网站| 欧美精品丝袜中出| 精品一区二区三区免费观看| 国产欧美一区二区三区网站| 91亚洲精品乱码久久久久久蜜桃| 亚洲国产欧美另类丝袜| 欧美成人综合网站| 成人一区二区视频| 亚洲超碰97人人做人人爱| 日韩三级电影网址| 99在线精品观看| 天堂成人国产精品一区| 国产欧美日韩不卡免费| 欧美三级日韩在线| 国产一区激情在线| 亚洲国产欧美在线| 久久精品一区二区三区不卡牛牛| 一本高清dvd不卡在线观看| 日本女优在线视频一区二区| 中文字幕欧美区| 欧美一区二区在线视频| 成人动漫中文字幕| 欧美96一区二区免费视频| 国产精品三级av在线播放| 91精品免费观看| 91在线观看成人| 久久精品国产精品青草| 亚洲黄一区二区三区| 精品电影一区二区三区| 欧美性猛交一区二区三区精品| 国产揄拍国内精品对白| 亚洲国产一二三| 日韩伦理av电影| 精品欧美久久久| 欧美色图12p| 不卡一区二区在线| 国产精品综合一区二区三区| 五月天激情综合网| 亚洲欧美另类小说| 欧美国产亚洲另类动漫| 亚洲精品在线观看视频| 91精品国产综合久久福利| 欧美在线播放高清精品| 成人av在线一区二区三区| 国产一区美女在线| 免费观看久久久4p| 婷婷综合五月天| 一区二区免费视频| 亚洲人成亚洲人成在线观看图片 | 欧美日韩一区视频| 国产精品日产欧美久久久久| 51久久夜色精品国产麻豆| 成人影视亚洲图片在线| 麻豆一区二区在线| 爽好多水快深点欧美视频| 一区二区三区四区中文字幕| 国产精品久久久久久久久搜平片| 久久综合99re88久久爱| 日韩色视频在线观看| 6080国产精品一区二区| 欧美日韩国产免费| 欧美日韩国产高清一区二区| 欧美中文字幕一区| 欧美性一区二区| 欧美性视频一区二区三区| 欧美午夜精品一区二区蜜桃| 欧美吞精做爰啪啪高潮| 欧洲精品在线观看| 欧美午夜免费电影| 欧美高清激情brazzers| 欧美三级电影一区| 色哟哟日韩精品| 成人av资源在线| www.欧美色图| 一本大道久久a久久精二百 | ●精品国产综合乱码久久久久| 国产欧美一区二区三区鸳鸯浴| 国产亚洲美州欧州综合国| 久久久噜噜噜久久人人看 | 欧美一级片在线看| 日韩小视频在线观看专区| 精品欧美一区二区久久| 久久久久久久久久久电影| 国产精品入口麻豆九色| 亚洲激情中文1区| 视频一区二区三区中文字幕| 蜜桃传媒麻豆第一区在线观看| 精品亚洲成a人| 从欧美一区二区三区| 91色porny在线视频| 欧美婷婷六月丁香综合色| 欧美一区二区三区精品| 久久综合精品国产一区二区三区 | 日韩一区二区三区视频| 久久久久9999亚洲精品| 亚洲色图欧美偷拍| 日本亚洲一区二区| 国产成人综合在线| 欧洲色大大久久| 欧美精品一区二区在线观看| 国产精品白丝在线| 性欧美疯狂xxxxbbbb| 国产麻豆视频一区二区| 色偷偷88欧美精品久久久| 91精品国产入口在线| 日本一区二区免费在线观看视频| 亚洲精品免费电影| 精品一区二区国语对白| 色综合 综合色| 精品国产乱码久久久久久老虎| 亚洲欧洲日韩在线| 日本不卡1234视频| 成人精品高清在线| 制服丝袜在线91| 国产精品黄色在线观看| 美女性感视频久久| 色综合色综合色综合色综合色综合| 欧美一区二区三区在线电影| 中文字幕制服丝袜一区二区三区| 免费三级欧美电影| 日本高清成人免费播放| 2020国产精品久久精品美国| 亚洲一卡二卡三卡四卡五卡| 国产91丝袜在线播放0| 欧美一级欧美一级在线播放| 亚洲精品高清在线观看| 国产精品一线二线三线精华| 777久久久精品| 一区二区三区加勒比av| 国产69精品久久99不卡| 日韩欧美综合在线| 天天综合网 天天综合色| 91麻豆精东视频| 欧美国产日产图区| 国产一区二区三区在线观看精品 | 久久日韩精品一区二区五区| 午夜精品一区二区三区电影天堂| 99久久综合狠狠综合久久| 26uuu久久综合| 日本麻豆一区二区三区视频| 日本韩国一区二区| 国产精品蜜臀在线观看| 国产精品一线二线三线精华| 日韩精品一区二区三区在线| 日韩不卡一区二区| 欧美调教femdomvk| 亚洲国产日日夜夜| 欧美三区在线观看| 亚洲一区二区三区三| 日本久久一区二区| 亚洲国产日日夜夜| 欧美日韩夫妻久久| 亚洲成a人在线观看| 欧美羞羞免费网站| 视频一区免费在线观看| 欧美一区二区三区日韩| 麻豆久久久久久| 精品国产免费一区二区三区香蕉| 久久99精品久久久久| 久久综合色婷婷| 国产乱码精品一区二区三区忘忧草 | 色哟哟国产精品免费观看| 亚洲欧美日韩中文字幕一区二区三区 | 久久久噜噜噜久久中文字幕色伊伊 | 欧美绝品在线观看成人午夜影视| 亚洲精品第一国产综合野| 91网站最新地址| 中文字幕一区不卡| 欧美在线观看你懂的| 亚洲精品乱码久久久久久久久 | 免费日韩伦理电影| 91免费版在线| 亚洲福利视频三区| 欧美三级日韩在线| 午夜婷婷国产麻豆精品| 欧美成人在线直播| 激情成人综合网| 久久久久久一级片| 91在线你懂得| 亚洲男人的天堂网| 在线精品观看国产| 亚洲国产中文字幕| 精品免费国产二区三区 | 国产综合久久久久久久久久久久| 精品剧情在线观看| 国产1区2区3区精品美女| 中文字幕一区二区三区色视频| 岛国av在线一区|