⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 kitl.c

📁 支持三星原产的S3C2413开发板
💻 C
字号:
//
// 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.
//
// -----------------------------------------------------------------------------
//
//	  THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
//	  ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
//	  THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
//	  PARTICULAR PURPOSE.
//  
// -----------------------------------------------------------------------------
#include <windows.h>
#include <bsp.h>
#include <kitl_cfg.h>

#define KITL_DBON 1

OAL_KITL_DEVICE g_kitlDevice;

const OAL_KITL_SERIAL_DRIVER *GetKitlSerialDriver (void);
const OAL_KITL_SERIAL_DRIVER *GetKitlUSBSerialDriver (void);
static OAL_KITL_ETH_DRIVER g_kitlEthCS8900A = OAL_ETHDRV_CS8900A;

volatile S3C2413_SSMCCTRL_REG *g_pMEMCTRLReg;
volatile S3C2413_CLKPWR_REG *g_pCLKPWRReg;
volatile S3C2413_IOPORT_REG *g_pIOPortReg;
volatile S3C2413_EBI_REG *g_pEBIReg;

BOOL USBSerKitl_POLL = FALSE;

BOOL InitKitlEtherArgs (OAL_KITL_ARGS *pKitlArgs)
{
	 KITLOutputDebugString ("+InitKitlEtherArgs\n");
   	// init flags
   	pKitlArgs->flags = OAL_KITL_FLAGS_ENABLED | OAL_KITL_FLAGS_VMINI;
#ifdef CS8900A_KITL_POLLMODE
   	pKitlArgs->flags |= OAL_KITL_FLAGS_POLL;
#endif //CS8900A_KITL_POLLMODE

#ifdef CS8900A_KITL_DHCP
	pKitlArgs->flags |= OAL_KITL_FLAGS_DHCP;
#endif //CS8900A_KITL_DHCP

	pKitlArgs->devLoc.IfcType		= Internal;
   	pKitlArgs->devLoc.BusNumber		= 0;
   	pKitlArgs->devLoc.LogicalLoc	= BSP_BASE_REG_PA_CS8900A_IOBASE;  // base address
   	pKitlArgs->devLoc.Pin		   = 0;
    
   	OALKitlStringToMAC(CS8900A_MAC,pKitlArgs->mac);

#ifndef CS8900A_KITL_DHCP
   	pKitlArgs->ipAddress			= OALKitlStringToIP(CS8900A_IP_ADDRESS);
   	pKitlArgs->ipMask				= OALKitlStringToIP(CS8900A_IP_MASK);
   	pKitlArgs->ipRoute				= OALKitlStringToIP(CS8900A_IP_ROUTER);
#endif CS8900A_KITL_DHCP

	g_kitlDevice.ifcType			= Internal;
   	g_kitlDevice.type			   = OAL_KITL_TYPE_ETH;
   	g_kitlDevice.pDriver			= (void *)&g_kitlEthCS8900A;

	/*********************************************************************/
	RETAILMSG(1, (TEXT("INFO: Using static IP address %s.\r\n"), pKitlArgs->ipAddress )); 
	RETAILMSG(1, (TEXT("INFO: Using subnet mask %s.\r\n"),	   pKitlArgs->ipMask)); 

	//setting EINT22(GPG14) as IRQ_LAN
	if (!(pKitlArgs->flags & OAL_KITL_FLAGS_POLL))
	{
		KITLOutputDebugString ("Ethernet KITL interrupt mode.\n");
		g_pIOPortReg = (S3C2413_IOPORT_REG *)OALPAtoVA(S3C2413_BASE_REG_PA_IOPORT, FALSE);
		g_pIOPortReg->GPGCON = (g_pIOPortReg->GPGCON & ~(0x3<<28)) | (0x2<<28);
		g_pIOPortReg->GPGDN |= 0x1<<14;
		g_pIOPortReg->EXTINT2 = (g_pIOPortReg->EXTINT2 & ~(0x7<<24)) | (0x1<<24);
	}
	KITLOutputDebugString ("-InitKitlEtherArgs\n");
	return TRUE;
}

BOOL InitKitlSerialArgs (OAL_KITL_ARGS *pKitlArgs)
{
	DWORD dwIoBase = UART_Kitl;

	// init flags
	pKitlArgs->flags = OAL_KITL_FLAGS_ENABLED | OAL_KITL_FLAGS_POLL;

	pKitlArgs->devLoc.LogicalLoc	= dwIoBase;
	pKitlArgs->devLoc.Pin		   = OAL_INTR_IRQ_UNDEFINED;
	pKitlArgs->baudRate			 = CBR_115200;
	pKitlArgs->dataBits			 = DATABITS_8;
	pKitlArgs->parity			   = PARITY_NONE;
	pKitlArgs->stopBits			 = STOPBITS_10;
	g_kitlDevice.type			   = OAL_KITL_TYPE_SERIAL;
	g_kitlDevice.pDriver			= (VOID*) GetKitlSerialDriver ();
	
	return TRUE;
}

BOOL InitKitlUSBSerialArgs (OAL_KITL_ARGS *pKitlArgs)
{
	DWORD dwIoBase = S3C2413_BASE_REG_PA_USBD + 0x140;

	// init flags
    pKitlArgs->flags = OAL_KITL_FLAGS_ENABLED | OAL_KITL_FLAGS_POLL;
#ifdef USBSER_KITL_POLL
	pKitlArgs->flags |= OAL_KITL_FLAGS_POLL;
	USBSerKitl_POLL = TRUE;
#endif

	pKitlArgs->devLoc.LogicalLoc	= dwIoBase;
	pKitlArgs->devLoc.Pin		   = IRQ_USBD;
 
	g_kitlDevice.type			   = OAL_KITL_TYPE_SERIAL;
	//the library is included now... Hsjang 060607
	g_kitlDevice.pDriver			= (VOID*) GetKitlUSBSerialDriver ();
	
	return TRUE;
}
//-----------------------------------------------------------------------------------------------------

void KITL_PortInit(void)
{

	volatile S3C2413_EBI_REG *s2413EBI = (S3C2413_EBI_REG *)OALPAtoVA(S3C2413_BASE_REG_PA_EBICTRL, FALSE);
	volatile S3C2413_SSMCCTRL_REG *s2413SSMC = (S3C2413_SSMCCTRL_REG *)OALPAtoVA(S3C2413_BASE_REG_PA_SSMCCTRL, FALSE);
	volatile S3C2413_CLKPWR_REG *s2413CLKPWR = (S3C2413_CLKPWR_REG *)OALPAtoVA(S3C2413_BASE_REG_PA_CLOCK_POWER, FALSE);

	OALMSG(TRUE, (TEXT("InitEthDevice Port.\r\n")));

	s2413CLKPWR->CLKDIVN = s2413CLKPWR->CLKDIVN | (1<<5);
	// EBI set for SROM
	s2413EBI->BANK_CFG = s2413EBI->BANK_CFG & ~((1<<4)|(1<<5));

	s2413SSMC->SMBIDCYR5 = 0x0;
	s2413SSMC->SMBWSTWRR5= 0xe;
	s2413SSMC->SMBWSTOENR5=0x4;
	s2413SSMC->SMBWSTWENR5=0x4;
	
	s2413SSMC->SMBWSTRDR5 = 0xe;
	s2413SSMC->SMBCR5 |= ((1<<2)|(1<<0));
	s2413SSMC->SMBCR5 &= ~((3<<20)|(3<<20)|(3<<12));
	s2413SSMC->SMBCR5 &= ~(3<<4);
	s2413SSMC->SMBCR5 |= (1<<4);
}
//-----------------------------------------------------------------------------------------------------
BOOL OALKitlStart()
{
	OAL_KITL_ARGS   kitlArgs, *pArgs;
	BOOL			fRet = FALSE;
	UCHAR			*szDeviceId,buffer[OAL_KITL_ID_SIZE]="\0";

	memset (&kitlArgs, 0, sizeof (kitlArgs));

	pArgs = (OAL_KITL_ARGS *)OALArgsQuery(OAL_ARGS_QUERY_KITL);
	szDeviceId = (CHAR*)OALArgsQuery(OAL_ARGS_QUERY_DEVID);

	// common parts
	kitlArgs.devLoc.IfcType = g_kitlDevice.ifcType
							= InterfaceTypeUndefined;
	g_kitlDevice.name	   = g_oalIoCtlPlatformType;

	KITLOutputDebugString ("OALKitlStart : ");

	
#ifdef KITL_SERIAL
	KITLOutputDebugString ("SERIAL\n");
	fRet = InitKitlSerialArgs (&kitlArgs);
	strcpy(buffer,"2413SerKitl");
	szDeviceId = buffer;
	g_kitlDevice.id = kitlArgs.devLoc.LogicalLoc;
#endif //KITL_SERIAL
#ifdef KITL_USBSERIAL
	KITLOutputDebugString ("USB SERIAL\n");
	fRet = InitKitlUSBSerialArgs (&kitlArgs);
	strcpy(buffer,"2413USBSerKitl");
	szDeviceId = buffer;
	g_kitlDevice.id = kitlArgs.devLoc.LogicalLoc;
#endif //KITL_USBSERIAL
#ifdef KITL_ETHERNET
	KITLOutputDebugString ("ETHERNET\n");

	KITL_PortInit();

	if (pArgs->devLoc.LogicalLoc == 0)
//	if (pArgs == NULL)
	{	
		 KITLOutputDebugString ("pArgs = NULL\n");
		fRet = InitKitlEtherArgs (&kitlArgs);
			OALKitlCreateName(BSP_DEVICE_PREFIX, kitlArgs.mac, buffer);
		szDeviceId = buffer;
			g_kitlDevice.id = kitlArgs.devLoc.LogicalLoc;
	}
	else
	{
    	KITLOutputDebugString ("Kitl args bring from argument setting of RAM\n");
		g_kitlDevice.ifcType			= Internal;
			g_kitlDevice.id					= BSP_BASE_REG_PA_CS8900A_IOBASE;  // base address
			g_kitlDevice.type			   = OAL_KITL_TYPE_ETH;
			g_kitlDevice.pDriver			= (void *)&g_kitlEthCS8900A;
		
		memcpy(&kitlArgs, pArgs, sizeof (kitlArgs));
		OALKitlCreateName(BSP_DEVICE_PREFIX, kitlArgs.mac, buffer);
		szDeviceId = buffer;
	
		fRet = TRUE;
	}

	 RETAILMSG(KITL_DBON, (
		L"DeviceId................. %hs\r\n", szDeviceId
	));
	RETAILMSG(KITL_DBON, (
		L"kitlArgs.flags............. 0x%x\r\n", kitlArgs.flags
	));
	RETAILMSG(KITL_DBON, (
		L"kitlArgs.devLoc.IfcType.... %d\r\n",   kitlArgs.devLoc.IfcType
	));
	RETAILMSG(KITL_DBON, (
		L"kitlArgs.devLoc.LogicalLoc. 0x%x\r\n", kitlArgs.devLoc.LogicalLoc
	));
	RETAILMSG(KITL_DBON, (
		L"kitlArgs.devLoc.PhysicalLoc 0x%x\r\n", kitlArgs.devLoc.PhysicalLoc
	));
	RETAILMSG(KITL_DBON, (
		L"kitlArgs.devLoc.Pin........ %d\r\n",   kitlArgs.devLoc.Pin
	));
	RETAILMSG(KITL_DBON, (
		L"kitlArgs.ip4address........ %s\r\n",   OALKitlIPtoString(kitlArgs.ipAddress)
	));


#endif //KITL_ETHERNET



	if (fRet == FALSE)
	{
		KITLOutputDebugString ("NONE\n");
		return FALSE;
	}

	if ((kitlArgs.flags & OAL_KITL_FLAGS_ENABLED) == 0)
	RETAILMSG(1, (TEXT("KITL is disabled.\r\n")));
	else
	RETAILMSG(1, (TEXT("KITL is enabeld.\r\n")));
	KITLOutputDebugString ("Call OALKitlInit : ");
	OALKitlInit (szDeviceId, &kitlArgs, &g_kitlDevice);
	return fRet;
}

//------------------------------------------------------------------------------
//
//  Function:  OALGetTickCount
//
//  This function is called by some KITL libraries to obtain relative time
//  since device boot. It is mostly used to implement timeout in network
//  protocol.
//

UINT32 OALGetTickCount()
{
	static ULONG count = 0;

	count++;
	return count/100;
}

// Define a dummy SetKMode function to satisfy the NAND FMD.
//
DWORD SetKMode (DWORD fMode)
{
	return(1);
}
//------------------------------------------------------------------------------

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -