merged branch into tip
authorJohn Kern <johnk@symbian.org>
Thu, 12 Nov 2009 09:14:36 -0800
changeset 19 05914789ab43
parent 18 cb29cd53a788 (current diff)
parent 16 2dd1d22cb0f3 (diff)
child 20 3bf560f85513
merged branch into tip
docs/wiki/ELF4ROM.doc
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/.hgignore	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,3 @@
+syntax: glob
+
+*~
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/applications/SymbianLogo_TextShell/BLD.INF	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,22 @@
+/*******************************************************************************
+* Copyright (c) 2009 Accenture
+* All rights reserved. This program and the accompanying materials
+* are made available under the terms of the Eclipse Public License v1.0
+* which accompanies this distribution, and is available at
+* http://www.eclipse.org/legal/epl-v10.html
+*
+* Contributors:
+* Accenture - Johnathan White
+
+*******************************************************************************/
+
+PRJ_PLATFORMS
+ARMV5
+
+PRJ_EXPORTS
+symbian_logo.bmp \svphostfs\symbian_logo.bmp
+symbianlogo.iby \epoc32\rom\include\symbianlogo.iby
+
+PRJ_MMPFILES
+SymbianLogo
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/applications/SymbianLogo_TextShell/README.txt	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,30 @@
+/*******************************************************************************
+* Copyright (c) 2009 Accenture
+* All rights reserved. This program and the accompanying materials
+* are made available under the terms of the Eclipse Public License v1.0
+* which accompanies this distribution, and is available at
+* http://www.eclipse.org/legal/epl-v10.html
+*
+* Contributors:
+* Accenture - Johnathan White
+
+*******************************************************************************/
+
+Submitter - Johnathan.White@accenture.com	
+
+Purpose - Simple TextShell console application which reads image file from filesystem and outputs to display
+
+Build from -  \sf\adaptation\qemu\applications\SymbianLogo_TextShell
+
+Using command - sbs -b bld.inf -c armv5 -j 1
+
+To include in textshell build modify \sf\os\kernelhwsrv\kernel\eka\rombuild\tshell.oby and add the line -
+
+#include <rom\include\symbianlogo.iby>
+
+Then Build textshell rom from \sf\os\kernelhwsrv\kernel\eka\rombuild\ using command - rom -v syborg -i armv5 -b udeb -noheader
+
+Then run QEMU from \symbian-qemu-0.9.1\bin using command -
+
+arm-none-symbianelf-qemu-system.exe -kernel \sf\os\kernelhwsrv\kernel\eka\rombuild\syborgarmv5d.img -M \sf\adaptation\qemu\baseport\syborg\syborg.dtb
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/applications/SymbianLogo_TextShell/SymbianLogo.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,101 @@
+/*******************************************************************************
+* Copyright (c) 2009 Accenture
+* All rights reserved. This program and the accompanying materials
+* are made available under the terms of the Eclipse Public License v1.0
+* which accompanies this distribution, and is available at
+* http://www.eclipse.org/legal/epl-v10.html
+*
+* Contributors:
+* Accenture - Johnathan White
+
+*******************************************************************************/
+// SymbianLogo.cpp
+
+#include <e32std.h>
+#include <e32cons.h>
+#include <f32file.h>
+#include <hal.h>
+#include <S32FILE.H> 
+
+void SetupConsoleL();
+void DisplayLogoL(CConsoleBase* aConsole);
+
+CConsoleBase* console;
+
+GLDEF_C TInt E32Main()									
+    {
+	CTrapCleanup* cleanup=CTrapCleanup::New();			
+	TRAPD(error,SetupConsoleL());	
+	if(error)
+		RDebug::Printf("SymbianLogo SetupError %d", error);
+	delete cleanup;										
+	return 0;									
+    }
+
+void SetupConsoleL()									
+    {
+	console=Console::NewL(_L("SymbianLogo"),
+	TSize(KConsFullScreen,KConsFullScreen));
+	
+	CleanupStack::PushL(console);
+	TRAPD(error,DisplayLogoL(console));					
+	if(error)
+		RDebug::Printf("SymbianLogo DisplayLogo Error %d", error);
+	CleanupStack::PopAndDestroy();						
+    }
+
+
+GLDEF_C void DisplayLogoL(CConsoleBase* aConsole)
+    {
+	TInt err =KErrNone;
+
+	//Connect to FileServer
+    RFs fs;
+    err = fs.Connect();
+
+	User::LeaveIfError(err);
+    
+	//Open file 
+	
+	/*
+	File \sf\adaptation\qemu\baseport\syborg\syborg.dts contains board model description, the hostfs@0 block defines both the host path
+	and target drive. The hostpath is by default set to \svphostfs\ and default drive number is 19 (S:\). If you would like to change this 
+	edit the dts file and use arm-none-symbianelf-dtc.exe to create updated dtb file
+	*/
+    RFile file; 
+    err = file.Open(fs, _L("S:\\symbian_logo.bmp"), EFileRead);
+    
+	User::LeaveIfError(err);
+
+	//Use to read stream from file on HostFs, first 54 bytes are header so skip
+	/*
+	symbian_logo.bmp is a 480*480 bmp file
+	*/
+    RFileReadStream filestream(file, 54);
+    
+	
+	//Obtain base address of framebuffer which will copy bitmap data into to display
+    TInt iScreenAddress;
+    HAL::Get(HAL::EDisplayMemoryAddress, iScreenAddress);
+	TUint8* pointer = (TUint8*)iScreenAddress;
+    
+
+
+
+    pointer+=640*479*4; //bitmap is 480*480 where as display is 640 *640, start by incrementing display pointer to last line required
+	for(TInt i=0;i<480;i++)
+		{
+		for(TInt j=0;j<1920;j++)
+    		{
+			*pointer = filestream.ReadUint8L(); //reads byte from file into correct offset in framebuffer
+			pointer++;
+    		}
+		
+		pointer-=1920; //decrement over offset between each line
+		pointer-=640*4; //decrement to start of next line    
+	}
+    
+    //Wait for User to press key then return
+	aConsole->Getch();
+	return;
+	}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/applications/SymbianLogo_TextShell/SymbianLogo.iby	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,23 @@
+/*******************************************************************************
+* Copyright (c) 2009 Accenture
+* All rights reserved. This program and the accompanying materials
+* are made available under the terms of the Eclipse Public License v1.0
+* which accompanies this distribution, and is available at
+* http://www.eclipse.org/legal/epl-v10.html
+*
+* Contributors:
+* Accenture - Johnathan White
+
+*******************************************************************************/
+
+#ifndef __SYMBIANLOGO_IBY__
+#define __SYMBIANLOGO_IBY__
+
+
+//actual logo console app
+file=\epoc32\release\armv5\urel\symbianlogo.exe sys\bin\symbianlogo.exe
+
+//library containing RFileReadStream
+file=\epoc32\release\armv5\urel\estor.dll sys\bin\estor.dll
+
+#endif
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/applications/SymbianLogo_TextShell/SymbianLogo.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,18 @@
+/*******************************************************************************
+* Copyright (c) 2009 Accenture
+* All rights reserved. This program and the accompanying materials
+* are made available under the terms of the Eclipse Public License v1.0
+* which accompanies this distribution, and is available at
+* http://www.eclipse.org/legal/epl-v10.html
+*
+* Contributors:
+* Accenture - Johnathan White
+
+*******************************************************************************/
+
+TARGET			SYMBIANLOGO.EXE
+TARGETTYPE		EXE
+SOURCEPATH		.
+SOURCE			symbianlogo.cpp
+SYSTEMINCLUDE		\epoc32\include
+LIBRARY			efsrv.lib euser.lib hal.lib estor.lib 
--- a/baseport/syborg/bld.inf	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/bld.inf	Thu Nov 12 09:14:36 2009 -0800
@@ -48,12 +48,24 @@
 kasyborg						// Variant library
 serial/serial					// Serial / UART ports
 fb/fb							// Framebuffer
+
+fb/fb_landscape
+fb/fb_portrait
+fb/fb_portrait_wvga
+
 keyboard/keyboard				// Keyboard
 pointer/pointer					// Pointer
+
+pointer/pointer_landscape.mmp
+pointer/pointer_portrait.mmp
+
 monitor/monap					// Crash Debugger output
 
 keymap/keymap					// Key mapping library
 
+estart/estart				// Customised estart to kick-start hostfs files system
+
+
 // platform device library - for flattened device tree (FDT)
 svpplatform/fdt
 
@@ -67,6 +79,10 @@
 svpsnapdriver/svpsnapdriver
 svpsnapdriver/snapapp
 
+
+//Add Sound Driver
+soundsc\soundsc
+
 PRJ_EXTENSIONS
 start		extension		base/config
 option		PREFIX			_syborg_
--- a/baseport/syborg/bootstrap/syborg.inc	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/bootstrap/syborg.inc	Thu Nov 12 09:14:36 2009 -0800
@@ -20,7 +20,11 @@
 ;---------------------------------------------------------------------------
 
 KHwRamBaseAddr		EQU    0x00000000
+
+; More ram required to boot SF image
 KHwRamSizeMb            EQU    128			; 128MB
+;KHwRamSizeMb            EQU    256			; 256MB
+
 
 KHwNorFlashBaseAddr     EQU    0x40000000
 KHwNorFlashSize         EQU    0x04000000   ; 64MB
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/estart/estart.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,58 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+
+
+#include        <variant.mmh>
+
+TARGET			VariantTarget(e32strt,exe)
+CAPABILITY		TCB WriteDeviceData DiskAdmin ProtServ AllFiles PowerMgmt
+
+TARGETTYPE		exe
+
+
+SOURCEPATH	\sf\os\kernelhwsrv\userlibandfileserver\fileserver\estart
+SOURCE			estart.cpp
+SOURCEPATH		../estart
+SOURCE			estartmain.cpp
+
+STRICTDEPEND
+
+//SOURCEPATH	.
+//DOCUMENT		 ../group/release.txt
+
+USERINCLUDE     \sf\os\kernelhwsrv\userlibandfileserver\fileserver\estart
+//SYSTEMINCLUDE	../inc /epoc32/include
+SYSTEMINCLUDE	/epoc32/include
+
+LIBRARY			efsrv.lib euser.lib hal.lib
+LIBRARY			domaincli.lib
+
+//#ifdef WINS
+//LIBRARY			emulator.lib
+//#endif
+
+//START WINS
+//BASEADDRESS		0x62000000
+//win32_library	kernel32.lib
+//END
+
+
+UID		0 0x10272C04
+VENDORID 0x70000001
+
+//#include "../group/f32.mmh"  	// Generic definitions for the whole f32 component
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/estart/estartmain.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,83 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+/*
+ *
+ * This file starts the HOSTFS local drive mapping
+ *
+ */
+
+#include <e32std.h>
+#include "estart.h"
+
+#define __ENABLE_HOSTFS
+
+/*!
+ * Customised estart class
+ */
+class TSyborgFSStartup : public TFSStartup
+	{
+public:
+#ifdef __ENABLE_HOSTFS
+	virtual void InitHostFS();
+#endif
+	};
+	
+
+#ifdef __ENABLE_HOSTFS
+
+/*
+ *
+ * Run the Host FS starter program
+ *
+ */ 
+void TSyborgFSStartup::InitHostFS()
+	{ 
+_LIT(KHostFSMounter, "z:\\sys\\bin\\SVPHOSTFS.EXE");
+
+	RProcess ws;
+	TInt r=ws.Create(KHostFSMounter, KNullDesC);
+	if (r == KErrNone)
+        {
+		TRequestStatus stat;
+		ws.Rendezvous(stat);
+		ws.Resume();
+		User::WaitForRequest(stat);		// wait for start or death
+		ws.Close();
+		}
+	}	
+#endif
+
+
+/*!
+ * Estart entry point
+ */
+GLDEF_C TInt E32Main()
+	{
+	
+	TSyborgFSStartup fsStart;
+	fsStart.Init();
+	
+	fsStart.Run();
+#ifdef __ENABLE_HOSTFS
+	fsStart.InitHostFS();
+#endif
+	fsStart.StartSystem();
+			
+	fsStart.Close();
+	return(0);
+	}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/estart/readme.txt	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,21 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+
+See \sf\os\kernelhwsrv\userlibandfileserver\fileserver\estart
+
+
--- a/baseport/syborg/fb/fb.mmp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/fb/fb.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -21,6 +21,9 @@
 TARGET			VariantTarget(lcd,dll)
 TARGETTYPE		kext
 
+MACRO __PORTRAIT_DISPLAY__
+
+
 SYSTEMINCLUDE	AsspNKernIncludePath
 SYSTEMINCLUDE	.
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/fb/fb_landscape.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,41 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+* Sosco
+*
+* Description:
+* Variant derived from fb.mmp
+*
+*/
+
+#include <variant.mmh>
+#include "kernel/kern_ext.mmh"
+
+TARGET			VariantTarget(lcd_landscape,dll)
+TARGETTYPE		kext
+
+SYSTEMINCLUDE	AsspNKernIncludePath
+SYSTEMINCLUDE	.
+
+SOURCEPATH		.
+SOURCE			syborg_fb.cpp
+
+LIBRARY			PlatformLib
+
+EPOCALLOWDLLDATA
+
+UID			    0x1000008d 0x100039e8
+VENDORID        0x70000001
+
+ROMTARGET		lcd.dll
+
+CAPABILITY		all
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/fb/fb_portrait.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,43 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+* Sosco
+*
+* Description:
+* Variant derived from fb.mmp
+*
+*/
+
+#include <variant.mmh>
+#include "kernel/kern_ext.mmh"
+
+MACRO __PORTRAIT_DISPLAY__
+
+TARGET			VariantTarget(lcd_portrait,dll)
+TARGETTYPE		kext
+
+SYSTEMINCLUDE	AsspNKernIncludePath
+SYSTEMINCLUDE	.
+
+SOURCEPATH		.
+SOURCE			syborg_fb.cpp
+
+LIBRARY			PlatformLib
+
+EPOCALLOWDLLDATA
+
+UID			    0x1000008d 0x100039e8
+VENDORID        0x70000001
+
+ROMTARGET		lcd.dll
+
+CAPABILITY		all
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/fb/fb_portrait_wvga.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,44 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+* Sosco
+*
+* Description:
+* Variant derived from fb.mmp
+*
+*/
+
+#include <variant.mmh>
+#include "kernel/kern_ext.mmh"
+
+MACRO __PORTRAIT_DISPLAY__
+MACRO __DISPLAY_WVGA__
+
+TARGET			VariantTarget(lcd_portrait_wvga,dll)
+TARGETTYPE		kext
+
+SYSTEMINCLUDE	AsspNKernIncludePath
+SYSTEMINCLUDE	.
+
+SOURCEPATH		.
+SOURCE			syborg_fb.cpp
+
+LIBRARY			PlatformLib
+
+EPOCALLOWDLLDATA
+
+UID			    0x1000008d 0x100039e8
+VENDORID        0x70000001
+
+ROMTARGET		lcd.dll
+
+CAPABILITY		all
\ No newline at end of file
--- a/baseport/syborg/fb/syborg_fb.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/fb/syborg_fb.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -197,9 +197,13 @@
 
   if(aMode != aInfo.iDisplayMode)
 	{
-	  aInfo.iOffsetToFirstPixel = KCOnfigOffsetToFirstPixel;
+
+	  aInfo.iOffsetToFirstPixel = KConfigOffsetToFirstPixel;
+
 	  aInfo.iIsPalettized       = KConfigIsPalettized;
-	  aInfo.iOffsetBetweenLines = KCOnfigOffsetBetweenLines;
+
+	  aInfo.iOffsetBetweenLines = KConfigOffsetBetweenLines;
+
 	  aInfo.iBitsPerPixel       = KConfigBitsPerPixel;
 	}
   return KErrNone;
@@ -208,7 +212,10 @@
 TInt DLcdPowerHandler::AllocateFrameBuffer()
 {
 	// Allocate physical RAM for video
-	TInt vSize = TSyborg::VideoRamSize();
+
+// Added only the comments
+	TInt vSize = TSyborg::VideoRamSize(); // Maximum display now 854 x 854
+
 
 	NKern::ThreadEnterCS();
 	TInt r = Epoc::AllocPhysicalRam(vSize,Syborg::VideoRamPhys);
@@ -251,8 +258,10 @@
 	iVideoInfo.iSizeInPixels.iWidth  = KConfigLcdWidth;
 	iVideoInfo.iSizeInPixels.iHeight = KConfigLcdHeight;
 	iVideoInfo.iDisplayMode = KConfigLcdDisplayMode;
-	iVideoInfo.iOffsetToFirstPixel = KCOnfigOffsetToFirstPixel;
-	iVideoInfo.iOffsetBetweenLines = KCOnfigOffsetBetweenLines;
+
+	iVideoInfo.iOffsetToFirstPixel = KConfigOffsetToFirstPixel;
+	iVideoInfo.iOffsetBetweenLines = KConfigOffsetBetweenLines;
+
 	iVideoInfo.iIsPalettized = KConfigIsPalettized;
 	iVideoInfo.iBitsPerPixel = KConfigBitsPerPixel;
 	iVideoInfo.iSizeInTwips.iWidth = KConfigLcdWidthInTwips;
@@ -446,8 +455,10 @@
 	iVideoInfo.iSizeInPixels.iWidth  = KConfigLcdWidth;
 	iVideoInfo.iSizeInPixels.iHeight = KConfigLcdHeight;
 	iVideoInfo.iDisplayMode = KConfigLcdDisplayMode;
-	iVideoInfo.iOffsetToFirstPixel = KCOnfigOffsetToFirstPixel;
-	iVideoInfo.iOffsetBetweenLines = KCOnfigOffsetBetweenLines;
+
+	iVideoInfo.iOffsetToFirstPixel = KConfigOffsetToFirstPixel;
+	iVideoInfo.iOffsetBetweenLines = KConfigOffsetBetweenLines;
+
 	iVideoInfo.iIsPalettized = KConfigIsPalettized;
 	iVideoInfo.iBitsPerPixel = KConfigBitsPerPixel;
 	iVideoInfo.iSizeInTwips.iWidth = KConfigLcdWidthInTwips;
--- a/baseport/syborg/fb/syborg_fb.h	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/fb/syborg_fb.h	Thu Nov 12 09:14:36 2009 -0800
@@ -24,15 +24,61 @@
 #include <kpower.h>
 #include <system.h>
 
+
+
+// The definition of __portrait_display__ in the MMP file affects
+// both the display and the pointer component, so both must be
+// rebuilt if this setting is changed.
+
+
 _LIT(KLitLcd,"SYBORG_FB");
 
-const TUint KConfigLcdWidth            = 640;
+
+#ifdef __PORTRAIT_DISPLAY__ // portrait display selected
+
+#	ifdef __DISPLAY_WVGA__
+
+#pragma comment(layout,"Portrait display enabled")
+const TUint KConfigLcdWidth            	= 854; // This must be left at 640, even with only 360 used by S60
+const TUint	KConfigLcdHeight	       	= 854;
+const TInt	KConfigLcdHeightInTwips     = 12860;
+const TInt	KConfigLcdWidthInTwips    	= 12860;
+const TUint	KConfigMouseWidth	       	= 480; // Usable width for the mouse driver
+const TUint	KConfigMouseMin			   	= 0;
+
+#	else //__DISPLAY_WVGA__
+
+#pragma comment(layout,"Portrait display enabled")
+const TUint KConfigLcdWidth            = 640; // This must be left at 640, even with only 360 used by S60
+const TUint	KConfigLcdHeight	       = 640;
+const TInt	KConfigLcdHeightInTwips     = 3550;
+const TInt	KConfigLcdWidthInTwips    = 3550;
+const TUint	KConfigMouseWidth	       = 360; // Usable width for the mouse driver
+
+const TUint	KConfigMouseMin			   = 0;
+#	endif //__DISPLAY_WVGA__
+
+
+
+
+#else // __PORTRAIT_DISPLAY__  Landscape display selected
+
+#pragma comment(layout,"Landscape display enabled")
+const TUint  KConfigLcdWidth            = 640;
 const TUint	KConfigLcdHeight	       = 480;
-const TInt	KConfigLcdWidthInTwips     = 9638;
-const TInt	KConfigLcdHeightInTwips    = 7370;
+const TInt	KConfigLcdWidthInTwips     = 3550;
+const TInt	KConfigLcdHeightInTwips    = 2670;
+const TUint	KConfigMouseWidth	       = 640; // Usable width for the mouse driver
+
+const TUint	KConfigMouseMin			   = 120; // mouse range is 120 - 480, not 0 - 360
+#endif // __PORTRAIT_DISPLAY__
+
+
 const TBool KConfigIsMono              = 0;
 const TBool KConfigIsPalettized        = 0;
-const TInt  KCOnfigOffsetToFirstPixel  = 0;
+
+const TInt  KConfigOffsetToFirstPixel  = 0;
+
 const TBool KConfigPixelOrderRGB       = 0;
 const TBool KConfigPixelOrderLandscape = 1;
 const TInt  KConfigLcdDisplayMode       = 2;
@@ -41,7 +87,13 @@
 
 
 const TInt  KConfigBitsPerPixel        = 24;
-const TInt  KCOnfigOffsetBetweenLines  = 2560;
+
+#ifdef __DISPLAY_WVGA__
+const TInt  KConfigOffsetBetweenLines  = 3416;
+#else //__DISPLAY_WVGA__
+const TInt  KConfigOffsetBetweenLines  = 2560;
+#endif //__DISPLAY_WVGA__
+
 
 class DLcdPowerHandler : public DPowerHandler
 {
@@ -72,7 +124,7 @@
   TInt GetSpecifiedDisplayModeInfo(TInt aMode, TVideoInfoV01& aInfo);
   TInt SetDisplayMode(TInt aMode);
   TInt AllocateFrameBuffer();
-  
+
   TBool iDisplayOn;
   DPlatChunkHw* iChunk;
   DPlatChunkHw* iSecureChunk;
@@ -83,7 +135,7 @@
   TDfcQue* iDfcQ;
   TMessageQue iMsgQ;					// to prevent a race condition with Power Manager trying to power up/down at the same time
   TDfc iPowerUpDfc;
-  TDfc iPowerDownDfc;	
+  TDfc iPowerDownDfc;
 
 private:
   TVideoInfoV01 iVideoInfo;
--- a/baseport/syborg/keyboard/syborg_keyboard.h	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/keyboard/syborg_keyboard.h	Thu Nov 12 09:14:36 2009 -0800
@@ -144,11 +144,13 @@
 	/*3c*/ EStdKeyF2,
 	/*3d*/ EStdKeyF3,
 	/*3e*/ EStdKeyF4,
-	/*3f*/ EStdKeyF5,
-	
-	/*40*/ EStdKeyF6,
-	/*41*/ EStdKeyF7,
-	/*42*/ EStdKeyF8,
+
+	/*3f*/ EStdKeyDevice0,	//EStdKeyF5,	SF: Left soft-key [EStdKeyApplication0]
+
+	/*40*/ EStdKeyDevice3,	//EStdKeyF6,	SF: OK key
+	/*41*/ EStdKeyDevice1,	//EStdKeyF7,	SF: Right soft-key
+	/*42*/ EStdKeyApplication0, //EStdKeyF8, SF Menu key
+
 	/*43*/ EStdKeyF9,
 	/*44*/ EStdKeyF10,
 	/*45*/ EStdKeyNull,
@@ -161,7 +163,9 @@
 	/*4c*/ EStdKeyNull,
 	/*4d*/ EStdKeyRightArrow,
 	/*4e*/ EStdKeyNull,
-	/*4f*/ EStdKeyNull,
+
+	/*4f*/ EStdKeyEnd,
+
 	
 	/*50*/ EStdKeyDownArrow,
 	/*51*/ EStdKeyPageDown,
--- a/baseport/syborg/keymap/keymap.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/keymap/keymap.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -1356,6 +1356,11 @@
 	{'0', '9'},
 	{'A', 'Z'},
 	{EStdKeyF1, EStdKeyDictaphoneRecord},
+
+	{EStdKeyDevice0,EStdKeyDeviceF},
+	{EStdKeyApplication0, EStdKeyApplicationF},
+	{EStdKeyYes, EStdKeyDecBrightness},
+
 	};
 
 LOCAL_D const TUint16 convKeyCodes_base[]=
@@ -1481,6 +1486,45 @@
     EKeyDictaphonePlay,
     EKeyDictaphoneStop,
     EKeyDictaphoneRecord,
+
+
+	EKeyDevice0,
+	EKeyDevice1,
+	EKeyDevice2,
+	EKeyDevice3,
+	EKeyDevice4,
+	EKeyDevice5,
+	EKeyDevice6,
+	EKeyDevice7,
+	EKeyDevice8,
+	EKeyDevice9,
+	EKeyDeviceA,
+	EKeyDeviceB,
+	EKeyDeviceC,
+	EKeyDeviceE,
+	EKeyDeviceE,
+	EKeyDeviceF,
+	EKeyApplication0,
+	EKeyApplication1,
+	EKeyApplication2,
+	EKeyApplication3,
+	EKeyApplication4,
+	EKeyApplication5,
+	EKeyApplication6,
+	EKeyApplication7,
+	EKeyApplication8,
+	EKeyApplication9,
+	EKeyApplicationA,
+	EKeyApplicationB,
+	EKeyApplicationC,
+	EKeyApplicationD,
+	EKeyApplicationE,
+	EKeyApplicationF,
+	EKeyYes,
+	EKeyNo,
+	EKeyIncBrightness,
+	EKeyDecBrightness
+
 	};
 
 // caps-lock: this table traps those scanCodes which are affected by caps-lock
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/pointer/pointer_landscape.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,48 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+* Sosco - derived from pointer.mmp
+*
+* Description:
+* epointer.dll for landscape mode
+*
+*/
+
+#include <variant.mmh>
+#include "kernel/kern_ext.mmh"
+
+TARGET			VariantTarget(epointer_landscape,dll)
+TARGETTYPE		kext
+LINKAS			epointer.dll
+
+SYSTEMINCLUDE   .
+SYSTEMINCLUDE	AsspNKernIncludePath
+
+SOURCEPATH		.
+SOURCE			syborg_pointer.cpp
+
+//LIBRARY			ekern.lib
+LIBRARY			PlatformLib
+
+//NOEXPORTLIBRARY
+
+//DEFFILE			../e32/~/empty.def
+//DEFFILE			./~/cmse.def
+
+//NOSTRICTDEF
+
+UID				0x100039cf 0x100000db
+VENDORID        0x70000001
+
+CAPABILITY 		all
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/pointer/pointer_portrait.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,50 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+* Sosco - derived from pointer.mmp
+*
+* Description:
+* epointer.dll for portrait mode
+*
+*/
+
+#include <variant.mmh>
+#include "kernel/kern_ext.mmh"
+
+MACRO __PORTRAIT_DISPLAY__
+
+TARGET			VariantTarget(epointer_portrait,dll)
+TARGETTYPE		kext
+LINKAS			epointer.dll
+
+SYSTEMINCLUDE   .
+SYSTEMINCLUDE	AsspNKernIncludePath
+
+SOURCEPATH		.
+SOURCE			syborg_pointer.cpp
+
+//LIBRARY			ekern.lib
+LIBRARY			PlatformLib
+
+//NOEXPORTLIBRARY
+
+//DEFFILE			../e32/~/empty.def
+//DEFFILE			./~/cmse.def
+
+//NOSTRICTDEF
+
+UID				0x100039cf 0x100000db
+VENDORID        0x70000001
+
+CAPABILITY 		all
+
+
--- a/baseport/syborg/pointer/syborg_pointer.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/pointer/syborg_pointer.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -20,10 +20,29 @@
 #include <syborg_priv.h>
 #include "syborg_pointer.h"
 
-TPointerRv::TPointerRv():
-  iRxDfc(RxDfc,this,Kern::DfcQue0(),1)
+
+_LIT(KPointerDfcQNamePre,"PointDFC");
+const TInt KDfcQuePriority = 27;
+
+
+
+TPointerRv::TPointerRv() //sosco :
+//  iRxDfc(RxDfc,this,Kern::DfcQue0(),1)
+
 {
   __DEBUG_PRINT("TPointerRv::TPointerRv()");
+
+
+ TInt err = Kern::DfcQInit(&iDfcQue, KDfcQuePriority, &KPointerDfcQNamePre);
+ if (err)
+ 	{
+	__KTRACE_OPT(KPANIC, Kern::Printf("TPointerRv::TPointerRv() Error creating dfcq (%d)", err));
+	}
+
+  iRxDfc = new TDfc(RxDfc,this,&iDfcQue,1);
+  __ASSERT_ALWAYS(iRxDfc!=NULL,Kern::Printf("Failed to create DFC"));
+
+
   TInt r = Interrupt::Bind(EIntPointer,Isr,this);
   if(r != KErrNone)
 	__KTRACE_OPT(KPANIC, Kern::Printf("TPointerRv::TPointerRv() Interrupt::Bind(%d)=%d",
@@ -43,7 +62,7 @@
   struct TPointerRv::PData* val = &iPDataFifo[iFifoPos];
   iFifoPos++;
   iFifoCount--;
-  
+
   if (iFifoPos == FIFO_SIZE)
 	iFifoPos = 0;
 
@@ -53,10 +72,10 @@
 void TPointerRv::FifoPush(struct TPointerRv::PData* val)
 {
   TInt slot;
-  
+
   if (iFifoCount == FIFO_SIZE)
 	return;
-  
+
   slot = iFifoPos + iFifoCount;
   if (slot >= FIFO_SIZE)
 	slot -= FIFO_SIZE;
@@ -74,7 +93,7 @@
 
   TInt reg = ReadReg(KHwBaseKmiPointer,POINTER_ID);
   WriteReg(KHwBaseKmiPointer,POINTER_INT_ENABLE,1);
-  
+
   TInt r = Kern::AddHalEntry(EHalGroupMouse,DoPointerHalFunction,this);
   if(r != KErrNone)
 	__KTRACE_OPT(KPANIC, Kern::Printf("TPointerRv::Init3(): Kern::AddHalEntry()=%d", r));
@@ -86,16 +105,24 @@
   r = Kern::HalFunction(EHalGroupDisplay, EDisplayHalCurrentModeInfo, (TAny*)&buf, NULL);
   if(r != KErrNone)
 	__KTRACE_OPT(KPANIC, Kern::Printf("TPointerRv::Init3(): Kern::HalFunction(EDisplayHalCurrentModeInfo)=%d", r));
-  
+
   iScreenWidth  = videoInfo.iSizeInPixels.iWidth;
   iScreenHeight = videoInfo.iSizeInPixels.iHeight;
   iDisplayMode  = videoInfo.iDisplayMode;
+
+  iVideoMem = videoInfo.iVideoAddress + videoInfo.iOffsetToFirstPixel;
+  iOffSetBetweenEachLine = 640;
+
   ix = iy = 0;
 
   iXFactor = Fixed(iScreenWidth) / Fixed(0x8000);
   iYFactor = Fixed(iScreenHeight) / Fixed(0x8000);
-  
+
   iFifoPos = iFifoCount = 0;
+
+
+  iFirstTime= ETrue;
+
 }
 
 
@@ -108,7 +135,7 @@
 
   //  i->ix += pd->x;
   //  i->iy += pd->y;
-  
+
   i->ix = int(Fixed(pd->x) * i->iXFactor);
   i->iy = int(Fixed(pd->y) * i->iYFactor);
 
@@ -155,15 +182,98 @@
 
 	}
  fin:
+
+
+  i->DisplayPointer();
+
+
   Kern::AddEvent(e);
   i->iLastBut = pd->but;
 }
 
+
+void TPointerRv::DisplayPointer()
+{
+
+TUint32 *pMem =0;
+TInt k=0;
+
+	if(!iFirstTime)
+	{
+
+	//restore old pointer position
+	pMem = (TUint32 *)iVideoMem;
+
+	pMem+= iYtop* iOffSetBetweenEachLine;
+	pMem+= iXleft;
+
+
+
+	for(TInt i=0;i<(iYbottom-iYtop);i++)
+	{
+		for(TInt j=0;j<(iXright-iXleft);j++)
+		{
+			*pMem = iImageStore[k];
+			pMem++;
+			k++;
+
+		}
+
+		pMem+= (iOffSetBetweenEachLine - iXright) + iXleft;
+	}
+	}
+
+	iFirstTime = EFalse;
+
+	//10*10 pixel pointer centered around position and check are within allowed bounds of screen
+	iXleft = ix - 5;
+
+	if(iXleft<0)
+		iXleft=0;
+
+	iXright = ix + 5;
+
+	if(iXright>iScreenWidth)
+		iXright = iScreenWidth;
+
+	iYtop = iy - 5;
+
+	if(iYtop<0)
+		iYtop=0;
+
+	iYbottom = iy +5;
+
+	if(iYbottom> iScreenHeight)
+		iYbottom=iScreenHeight;
+
+	pMem = (TUint32 *)iVideoMem;
+	k=0;
+
+	pMem+= iYtop* iOffSetBetweenEachLine;
+	pMem+= iXleft;
+
+	for(TInt i=0;i<(iYbottom-iYtop);i++)
+	{
+		for(TInt j=0;j<(iXright-iXleft);j++)
+		{
+			iImageStore[k] = *pMem;
+			*pMem = 0;
+			pMem++;
+			k++;
+
+		}
+
+		pMem+= (iOffSetBetweenEachLine - iXright) + iXleft;
+	}
+
+}
+
+
 void TPointerRv::RxDfc(TAny* aPtr)
 {
   __DEBUG_PRINT("TPointerRv::RxDfc");
 
-  TPointerRv* i = static_cast<TPointerRv*>(aPtr);  
+  TPointerRv* i = static_cast<TPointerRv*>(aPtr);
 
   while(i->iFifoCount>0) {
 	struct TPointerRv::PData *pd= i->FifoPop();
@@ -178,19 +288,30 @@
   TPointerRv& k = *(TPointerRv*)aPtr;
   // interrupts are now auto clear
 
-  while(ReadReg(KHwBaseKmiPointer, POINTER_FIFO_COUNT)!=0) {
+
+  while(ReadReg(KHwBaseKmiPointer, POINTER_FIFO_COUNT)!=0)
+  {
+
+	WriteReg(KHwBaseKmiPointer,POINTER_LATCH,1);
+	// SOSCO: moved to here, as the buffer seems to be running one notch out,
+	// writing to the pointer latch first seems to return the correct FIFO entry.
+
 	struct TPointerRv::PData pd;
 	pd.x = ReadReg(KHwBaseKmiPointer,POINTER_X);
 	pd.y = ReadReg(KHwBaseKmiPointer,POINTER_Y);
 	pd.z = ReadReg(KHwBaseKmiPointer,POINTER_Z);
-	pd.but = ReadReg(KHwBaseKmiPointer,POINTER_BUTTONS);  
+	pd.but = ReadReg(KHwBaseKmiPointer,POINTER_BUTTONS);
 	k.FifoPush(&pd);
-	WriteReg(KHwBaseKmiPointer,POINTER_LATCH,0);	
+
+// SOSCO - moved	WriteReg(KHwBaseKmiPointer,POINTER_LATCH,1);
+
   }
-  
+
   //  WriteReg(KHwBaseKmiPointer,POINTER_CLEAR_INT,0);
-  Interrupt::Clear(EIntPointer); 
-  k.iRxDfc.Add();
+  Interrupt::Clear(EIntPointer);
+
+  k.iRxDfc->Add();
+
 }
 
 TInt TPointerRv::DoPointerHalFunction(TAny* aThis, TInt aFunction, TAny* a1, TAny* a2)
@@ -210,24 +331,28 @@
 	  {
 		kumemput32(a1, (TBool*)&iPointerOn, sizeof(TBool));
 		break;
-	  }			
+	  }
 	case EMouseHalSetMouseState:
 	  {
+
+		  /* SOSCO - removed, causes platsec error
 	        __SECURE_KERNEL(
 	           if(!Kern::CurrentThreadHasCapability(ECapabilityMultimediaDD,
 		        __PLATSEC_DIAGNOSTIC_STRING("Checked by Hal function EMouseHalSetMouseState")))
 		     return KErrPermissionDenied;
 		   );
+		   */
+
 		if(((TBool)a1 == HAL::EMouseState_Visible) && (iPointerOn == (TBool)EFalse))
 		  {
 			iPointerOn=(TBool)ETrue;
-		  }            
-		else if(((TBool)a1 == HAL::EMouseState_Invisible) && (iPointerOn==(TBool)ETrue))        	    
+		  }
+		else if(((TBool)a1 == HAL::EMouseState_Invisible) && (iPointerOn==(TBool)ETrue))
 		  {
 			iPointerOn=(TBool)EFalse;
-		  }            
+		  }
 		break;
-	  }            
+	  }
 	case EMouseHalMouseInfo:
 	  {
 		TPckgBuf<TMouseInfoV01> vPckg;
@@ -239,30 +364,38 @@
 		xyinfo.iOffsetToDisplay.iY = 0;
 		Kern::InfoCopy(*(TDes8*)a1,vPckg);
 		break;
-	  }		    
+	  }
         case EMouseHalSetMouseSpeed:
 	  {
+
+		  /* SOSCO - removed, causes platsec error
 	        __SECURE_KERNEL(
 	           if(!Kern::CurrentThreadHasCapability(ECapabilityMultimediaDD,
 		        __PLATSEC_DIAGNOSTIC_STRING("Checked by Hal function EMouseHalSetMouseSpeed")))
 		     return KErrPermissionDenied;
 		   );
+		   */
+
 		// fall thru to NotSupported
 	  }
         case EMouseHalSetMouseAcceleration:
 	  {
+
+		  /* SOSCO - removed, causes platsec error
 	        __SECURE_KERNEL(
 	           if(!Kern::CurrentThreadHasCapability(ECapabilityMultimediaDD,
 		        __PLATSEC_DIAGNOSTIC_STRING("Checked by Hal function EMouseHalSetMouseAcceleration")))
 		     return KErrPermissionDenied;
 		   );
+		   */
+
 		// fall thru to NotSupported
 	  }
 	default:
 	  {
 		r = KErrNotSupported;
 		break;
-	  }			
+	  }
 	}
   return r;
 }
--- a/baseport/syborg/pointer/syborg_pointer.h	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/pointer/syborg_pointer.h	Thu Nov 12 09:14:36 2009 -0800
@@ -60,16 +60,35 @@
   static void RxDfc(TAny* aPtr );
   static void Process(TPointerRv *i, struct PData *);
 
-  TDfc iRxDfc;
+  void DisplayPointer();
+
+
+
+  //TDfc iRxDfc;
+  TDfcQue iDfcQue;
+  TDfc* iRxDfc;
+
 	
   TBool iPointerOn;       // cursor visiability
   TInt  iScreenWidth;
   TInt  iScreenHeight;
   TInt  iDisplayMode;
 
+  TInt  iVideoMem;
+  TInt  iOffSetBetweenEachLine;
+
+
   TInt ix,iy;
   TInt iLastBut;
 
+
+  TBool iFirstTime;
+  TInt iXleft;
+  TInt iXright;
+  TInt iYtop;
+  TInt iYbottom;
+  TInt iImageStore[100];
+
   
  public:
 
--- a/baseport/syborg/rom/base_syborg.iby	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/rom/base_syborg.iby	Thu Nov 12 09:14:36 2009 -0800
@@ -32,7 +32,11 @@
 bootbinary=		KERNEL_DIR\_PLATFORM_NAME_bootloader_bootrom.bin
 
 debugport 0
-romsize=0x2000000
+
+// Fixed rom over flow
+//romsize=0x2000000
+romsize=0x8000000
+
 romlinearbase=0x80000000
 romalign=0x10
 kerneldataaddress=0xC8000000
@@ -64,14 +68,35 @@
 // IEEE-mode VFP support
 extension[VARID]=	KERNEL_DIR\DEBUG_DIR\evfp.dll			        \sys\bin\evfp.dll
 
-extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_lcd.dll		\sys\bin\lcd.dll
+
+// Changes allowing us of either portrait or landscape mode
+//extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_lcd.dll		\sys\bin\lcd.dll
+#ifdef _PORTRAIT_
+
+#	ifdef _WVGA_
+extension[VARID]=KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_lcd_portrait_wvga.dll		    \sys\bin\lcd.dll
+#	else //_WVGA_
+extension[VARID]=KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_lcd_portrait.dll		    \sys\bin\lcd.dll
+#	endif //_WVGA_
+
+#else
+extension[VARID]=KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_lcd_landscape.dll		    \sys\bin\lcd.dll
+#endif
 
 device[VARID]=		KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_eserial.pdd		\sys\bin\euart1.pdd
 device[VARID]=		KERNEL_DIR\DEBUG_DIR\ecomm.ldd				\sys\bin\ecomm.ldd
 
 extension[VARID]=	KERNEL_DIR\DEBUG_DIR\elocd.ldd				\sys\bin\elocd.ldd
 
-extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_epointer.dll	\sys\bin\epointer.dll
+
+// Changes allowing us of either portrait or landscape mode
+//extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_epointer.dll	\sys\bin\epointer.dll
+#ifdef _PORTRAIT_
+extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_epointer_portrait.dll	\sys\bin\epointer.dll
+#else
+extension[VARID]=KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_epointer_landscape.dll	        \sys\bin\epointer.dll
+#endif
+
 extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_medint.pdd	        \sys\bin\medint.pdd
 
 extension[VARID]=	KERNEL_DIR\DEBUG_DIR\exstart.dll		 	\sys\bin\exstart.dll
@@ -80,13 +105,18 @@
 extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_ekeyb.dll		\sys\bin\ekeyb.dll
 
 // Kernel pipe
-device[VARID]=		KERNEL_DIR\DEBUG_DIR\pipelib.ldd			\sys\bin\pipelib.ldd
+
+//device[VARID]	=KERNEL_DIR\DEBUG_DIR\pipelib.ldd					    \sys\bin\pipelib.ldd
+
 
 // Host Filesystem
 extension[VARID]=	KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_svphostfsdriver.ldd sys\bin\svphostfsdriver.ldd
 file=			KERNEL_DIR\DEBUG_DIR\svphostfsy.fsy			sys\bin\svphostfsy.fsy
 file=			KERNEL_DIR\DEBUG_DIR\svphostfs.exe			sys\bin\svphostfs.exe
-file=			KERNEL_DIR\DEBUG_DIR\svphostfsstart.exe			sys\bin\sysstart.exe
+
+// Conflicts with /epoc32/rom/include/core/os/starter.iby
+//file=			KERNEL_DIR\DEBUG_DIR\svphostfsstart.exe			sys\bin\sysstart.exe
+
 
 // file=			KERNEL_DIR\DEBUG_DIR\stdnew.dll				sys\bin\stdnew.dll
 
@@ -98,10 +128,17 @@
 data=			EPOCROOT##epoc32\rom\syborg\estart.txt			\sys\data\estart.txt
 
 define	HAL_DLL		_PLATFORM_NAME_hal.dll
-define	ESTART_EXE	e32strt.exe
+
+//define	ESTART_EXE	e32strt.exe
+define	ESTART_EXE		_PLATFORM_NAME_e32strt.exe	// customised ESTART
+
 define	KEYMAP_FILE	_PLATFORM_NAME_ekdata
 #define	SCDV_DLL        _PLATFORM_NAME_scdv.dll
 #define	EUSER_DLL	_PLATFORM_NAME_euser.dll
 
+
+device[VARID]	=KERNEL_DIR\DEBUG_DIR\_PLATFORM_NAME_soundsc.pdd	    \sys\bin\soundsc.pdd
+device[VARID]	=KERNEL_DIR\DEBUG_DIR\esoundsc.ldd				            \sys\bin\esoundsc.ldd
+
 #endif  // __BASE_SYBORG_IBY__
 
--- a/baseport/syborg/rom/kernel.iby	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/rom/kernel.iby	Thu Nov 12 09:14:36 2009 -0800
@@ -53,7 +53,11 @@
 extension[VARID]=	\epoc32\release\##KMAIN##\##BUILD##\_##VARIANT##_svphostfsdriver.ldd	\sys\bin\svphostfsdriver.ldd
 file=			\epoc32\release\##KMAIN##\##BUILD##\svphostfsy.fsy			\sys\bin\svphostfsy.fsy
 file=			\epoc32\release\##KMAIN##\##BUILD##\svphostfs.exe			\sys\bin\svphostfs.exe
-file=			\epoc32\release\##KMAIN##\##BUILD##\svphostfsstart.exe			\sys\bin\sysstart.exe
+
+//file=			\epoc32\release\##KMAIN##\##BUILD##\svphostfsstart.exe			\sys\bin\sysstart.exe
+#define CUSTOM_ESTART
+file=				\epoc32\release\##KMAIN##\##BUILD##\_##VARIANT##_e32strt.exe		sys\bin\estart.exe HEAPMAX (0x10000)
+
 
 // Snap Driver
 extension[VARID]=	\epoc32\release\##KMAIN##\##BUILD##\_##VARIANT##_svpsnapdriver.ldd  \sys\bin\svpsnapdriver.ldd
@@ -68,3 +72,7 @@
 
 extension[VARID]=	\epoc32\release\##KMAIN##\##BUILD##\_##VARIANT##_MEDINT.PDD	    \sys\bin\MEDINT.PDD
 //device[VARID]=	\epoc32\release\##KMAIN##\##BUILD##\D_DEBUG.LDD					\sys\bin\D_DEBUG.LDD
+
+device[VARID]	= \epoc32\release\##KMAIN##\##BUILD##\_##VARIANT##_soundsc.pdd	    \sys\bin\soundsc.pdd
+device[VARID]	= \epoc32\release\##KMAIN##\##BUILD##\esoundsc.ldd				            \sys\bin\esoundsc.ldd
+
--- a/baseport/syborg/serial/syborg_serial.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/serial/syborg_serial.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -156,6 +156,10 @@
 		break;
 	  WriteReg(iPortAddr, SERIAL_DATA, r);
 	}
+
+	iLdd->iTxError = KErrNone;
+	iLdd->iTxCompleteDfc.Add();
+
 }
 
 TUint DCommSyborgSoc::Signals() const
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/soundsc/shared_sound.h	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,90 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#ifndef __SYBORGSHARED_SOUND_H__
+#define __SYBORGSHARED_SOUND_H__
+
+#include <soundsc.h>
+
+#ifdef _DEBUG
+#define SYBORG_SOUND_DEBUG(x...) Kern::Printf(x)
+#else
+#define SYBORG_SOUND_DEBUG(x...)
+#endif
+
+class DDriverSyborgSoundScPddFactory;
+
+class DDriverSyborgSoundScPdd : public DSoundScPdd
+	{
+public:
+
+	DDriverSyborgSoundScPdd();
+	~DDriverSyborgSoundScPdd();
+	TInt DoCreate();
+	void GetChunkCreateInfo(TChunkCreateInfo& aChunkCreateInfo);
+	void Caps(TDes8& aCapsBuf) const;
+	TInt MaxTransferLen() const;
+	TInt SetConfig(const TDesC8& aConfigBuf);
+	TInt SetVolume(TInt aVolume);
+	TInt StartTransfer();
+	TInt TransferData(TUint aTransferID, TLinAddr aLinAddr, TPhysAddr aPhysAddr, TInt aNumBytes);
+	void StopTransfer();
+	TInt PauseTransfer();
+	TInt ResumeTransfer();
+	TInt PowerUp();
+	void PowerDown();
+	TInt CustomConfig(TInt aFunction, TAny* aParam);
+	void Callback(TUint aTransferID, TInt aTransferResult, TInt aBytesTransferred);
+
+	void SetCaps();
+	TDfcQue* DfcQ(TInt aUnit);
+	
+	TInt CalculateBufferTime(TInt aNumBytes);
+
+public:
+	
+	DDriverSyborgSoundScPddFactory*	iPhysicalDevice;
+	
+	class TTransferArrayInfo{
+
+public:
+	TUint 						iTransferID;
+	TLinAddr 					iLinAddr;
+	TInt 						iNumBytes;
+	TInt						iPlayTime;
+	};
+	
+	RArray<TTransferArrayInfo> iTransferArray;
+	
+	NTimer						iTimer;
+	
+	TInt						iUnitType; //Play or Record
+	
+private:
+
+	TSoundFormatsSupportedV02	iCaps;
+	
+	TCurrentSoundFormatV02		iConfig;
+	
+
+
+	};
+
+
+
+
+#endif 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/soundsc/shared_txsound.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,312 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#include "shared_sound.h"
+#include "variant_sound.h"
+
+void TimerCallback(TAny* aData)
+	{
+	DDriverSyborgSoundScPdd * soundscpdd = (DDriverSyborgSoundScPdd*) aData;
+		
+	soundscpdd->Callback(soundscpdd->iTransferArray[0].iTransferID, KErrNone, soundscpdd->iTransferArray[0].iNumBytes);
+	
+	}
+
+
+DDriverSyborgSoundScPdd::DDriverSyborgSoundScPdd() : iTimer(TimerCallback,this)
+	{
+
+	}
+
+DDriverSyborgSoundScPdd::~DDriverSyborgSoundScPdd()
+	{
+	iTimer.Cancel();
+	}
+
+
+TInt DDriverSyborgSoundScPdd::DoCreate()
+	{
+
+	SetCaps();
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::DoCreate TxPdd");
+	
+	return KErrNone;
+	}
+
+void DDriverSyborgSoundScPdd::GetChunkCreateInfo(TChunkCreateInfo& aChunkCreateInfo)
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::GetChunkCreateInfo TxPdd");
+	
+	aChunkCreateInfo.iType = TChunkCreateInfo::ESharedKernelMultiple;
+	aChunkCreateInfo.iMapAttr = EMapAttrFullyBlocking; 	// No caching
+	aChunkCreateInfo.iOwnsMemory = ETrue; 				// Using RAM pages
+	aChunkCreateInfo.iDestroyedDfc = NULL; 				// No chunk destroy DFC
+	}
+
+void DDriverSyborgSoundScPdd::Caps(TDes8& aCapsBuf) const
+	{
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::Caps TxPdd");
+	
+	// Fill the structure with zeros in case it is a newer version than we know about
+	aCapsBuf.FillZ(aCapsBuf.MaxLength());
+
+	// And copy the capabilities into the packaged structure
+	TPtrC8 ptr((const TUint8*) &iCaps, sizeof(iCaps));
+	aCapsBuf = ptr.Left(Min(ptr.Length(), aCapsBuf.MaxLength()));
+	}
+
+TInt DDriverSyborgSoundScPdd::SetConfig(const TDesC8& aConfigBuf)
+	{
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::SetConfig TxPdd");
+	
+	// Read the new configuration from the LDD
+	TCurrentSoundFormatV02 config;
+	TPtr8 ptr((TUint8*) &config, sizeof(config));
+	Kern::InfoCopy(ptr, aConfigBuf);
+
+	iConfig = config;
+	
+	return KErrNone;
+	}
+
+
+TInt DDriverSyborgSoundScPdd::SetVolume(TInt aVolume)
+	{
+	
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::Setvolume TxPdd");
+	
+	return KErrNone;
+	}
+
+
+TInt DDriverSyborgSoundScPdd::StartTransfer()
+	{
+	
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::starttransfer TxPdd");
+	
+	//Prepare for transfer
+	return KErrNone;
+	
+	}
+
+TInt DDriverSyborgSoundScPdd::CalculateBufferTime(TInt aNumBytes)
+	{
+	
+	TUint samplerate=0;
+
+	// Let the compiler perform an integer division of rates
+	switch(iConfig.iRate)
+		{
+		case ESoundRate7350Hz: 	samplerate = 7350; break;
+		case ESoundRate8000Hz: 	samplerate = 8000; break;
+		case ESoundRate8820Hz: 	samplerate = 8820; break;
+		case ESoundRate9600Hz: 	samplerate = 9600; break;
+		case ESoundRate11025Hz: samplerate = 11025; break;
+		case ESoundRate12000Hz: samplerate = 12000; break;
+		case ESoundRate14700Hz:	samplerate = 14700; break;
+		case ESoundRate16000Hz: samplerate = 16000; break;
+		case ESoundRate22050Hz: samplerate = 22050; break;
+		case ESoundRate24000Hz: samplerate = 24000; break;
+		case ESoundRate29400Hz: samplerate = 29400; break;
+		case ESoundRate32000Hz: samplerate = 32000; break;
+		case ESoundRate44100Hz: samplerate = 44100; break;
+		case ESoundRate48000Hz: samplerate = 48000; break;
+		}
+
+
+	// integer division by number of channels
+	aNumBytes /= iConfig.iChannels;
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::iChannels =%d", iConfig.iChannels);
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::iEncoding =%d", iConfig.iEncoding);
+	
+	// integer division by bytes per sample
+	switch(iConfig.iEncoding)
+		{
+		case ESoundEncoding8BitPCM: break;
+		case ESoundEncoding16BitPCM: aNumBytes /= 2; break;
+		case ESoundEncoding24BitPCM: aNumBytes /= 3; break;
+		}
+
+	return (aNumBytes * 1000) / samplerate; //return time in milliseconds
+	
+
+	}
+
+TInt DDriverSyborgSoundScPdd::TransferData(TUint aTransferID, TLinAddr aLinAddr, TPhysAddr /*aPhysAddr*/, TInt aNumBytes)
+	{
+
+	//function wil get called multiple times while transfer is in progress therefore keep fifo queue of requests
+	TTransferArrayInfo transfer;	
+		
+	transfer.iTransferID = aTransferID;
+	transfer.iLinAddr = aLinAddr;
+	transfer.iNumBytes = aNumBytes;
+	
+	//calculate the amount of time required to play/record buffer
+	TInt buffer_play_time = CalculateBufferTime(aNumBytes);
+	TInt timerticks = NKern::TimerTicks(buffer_play_time);
+	transfer.iPlayTime = timerticks;
+	
+	iTransferArray.Append(transfer);
+	
+	//Timer will callback when correct time has elapsed, will return KErrInUse if transfer
+	//already active, this is ok becuase will be started again in callback
+	TInt err = iTimer.OneShot(timerticks, ETrue);
+	
+	
+	return KErrNone;
+	}
+
+void DDriverSyborgSoundScPdd::StopTransfer()
+	{
+	// Stop transfer
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::stoptransfer TxPdd");
+	
+	//If timer is currently active then cancel it and call back buffer
+	if(iTimer.Cancel())
+		{
+		Callback(iTransferArray[0].iTransferID, KErrNone, iTransferArray[0].iNumBytes);
+		}
+		
+
+	}
+
+
+TInt DDriverSyborgSoundScPdd::PauseTransfer()
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::pausetransfer TxPdd");
+	//Pause Transfer
+	
+	return KErrNone;
+	}
+
+
+TInt DDriverSyborgSoundScPdd::ResumeTransfer()
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::resumetransfer TxPdd");
+	//Resume Transfer
+	
+	return KErrNone;
+	}
+
+TInt DDriverSyborgSoundScPdd::PowerUp()
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::PowerUp TxPdd");
+	return KErrNone;
+	}
+
+void DDriverSyborgSoundScPdd::PowerDown()
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::Powerdown TxPdd");
+	}
+
+TInt DDriverSyborgSoundScPdd::CustomConfig(TInt /*aFunction*/,TAny* /*aParam*/)
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::customconfig TxPdd");
+	return KErrNotSupported;
+	}
+
+
+void DDriverSyborgSoundScPdd::Callback(TUint aTransferID, TInt aTransferResult, TInt aBytesTransferred)
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::playcallback TxPdd");
+	//Callback when Transfer completes or is stopped
+	
+	iTransferArray.Remove(0);
+	
+	if(iUnitType == KSoundScTxUnit0)
+		{
+		Ldd()->PlayCallback(aTransferID, aTransferResult, aBytesTransferred);
+		}
+	else if(iUnitType == KSoundScRxUnit0)
+		{
+		Ldd()->RecordCallback(aTransferID, aTransferResult, aBytesTransferred);
+		}
+	
+	if(	iTransferArray.Count()>0)
+		{
+		iTimer.OneShot(iTransferArray[0].iPlayTime, ETrue);
+		}
+	
+	}
+
+TDfcQue*DDriverSyborgSoundScPdd::DfcQ(TInt /* aUnit*/ )
+	{
+	return iPhysicalDevice->iDfcQ;
+	}
+
+
+TInt DDriverSyborgSoundScPdd::MaxTransferLen() const
+	{
+	
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::MaxTransferLen TxPdd");
+	
+	TInt maxlength = 200*1024;
+	return maxlength;
+	}
+
+
+void DDriverSyborgSoundScPdd::SetCaps()
+	{
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPdd::SetCaps TxPdd");
+	
+	if(iUnitType == KSoundScTxUnit0)
+		{
+		// The data transfer direction for this unit is play
+		iCaps.iDirection = ESoundDirPlayback;
+		}
+	else if(iUnitType == KSoundScTxUnit0)
+		{
+		// The data transfer direction for this unit is play
+		iCaps.iDirection = ESoundDirRecord;
+		}
+	
+	// This unit supports both mono and stereo
+	iCaps.iChannels = (KSoundMonoChannel | KSoundStereoChannel);
+
+	// This unit supports only some of the sample rates offered by Symbian OS
+	iCaps.iRates = (KSoundRate8000Hz | KSoundRate11025Hz | KSoundRate12000Hz | KSoundRate16000Hz |
+					KSoundRate22050Hz | KSoundRate24000Hz | KSoundRate32000Hz | KSoundRate44100Hz |
+					KSoundRate48000Hz);
+
+	// This unit only supports 16bit PCM encoding
+	iCaps.iEncodings = KSoundEncoding16BitPCM;
+
+	// This unit only supports interleaved data format when playing stereo;  that is, a PCM data
+	// stream where the left and right channel samples are interleaved as L-R-L-R-L-R etc.
+	iCaps.iDataFormats = KSoundDataFormatInterleaved;
+
+	// The iRequestMinSize member is named badly.  It is actually the value of which the length samples
+	// must be a multiple of.  ie.  The sample length % iRequestMinSize must == 0.  This value must always
+	// be a power of 2
+	iCaps.iRequestMinSize = 4;
+
+	// The logarithm to base 2 of the alignment required for request arguments.  DMA requests must be
+	// aligned to a 32 bit boundary
+	iCaps.iRequestAlignment = 2;
+
+	// This unit is not capable of detecting changes in hardware configuration
+	iCaps.iHwConfigNotificationSupport = EFalse;
+	}
+
+
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/soundsc/soundsc.mmp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,32 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#include		<variant.mmh>
+#include		"kernel/kern_ext.mmh"
+
+SYSTEMINCLUDE		/epoc32/include/drivers
+
+
+TARGET			VariantTarget(soundsc,pdd)
+TARGETTYPE		pdd
+ROMTARGET		soundsc.pdd
+
+SOURCE			shared_txsound.cpp
+SOURCE			variant_sound.cpp
+
+CAPABILITY		all
+EPOCALLOWDLLDATA
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/soundsc/variant_sound.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,128 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#include "variant_sound.h"
+
+_LIT(KSoundScPddName, "SoundSc.Syborg");
+
+
+DECLARE_STANDARD_PDD()
+	{
+	return new DDriverSyborgSoundScPddFactory;
+	}
+
+
+DDriverSyborgSoundScPddFactory::DDriverSyborgSoundScPddFactory()
+	{
+
+	iUnitsMask = ((1 << KSoundScTxUnit0) | (1 << KSoundScRxUnit0));
+
+	iVersion = RSoundSc::VersionRequired();
+	}
+
+
+TInt DDriverSyborgSoundScPddFactory::Install()
+	{
+	_LIT(KAudioDFC, "AUDIO DFC");
+	// Get a pointer to the the McBSP's DFC Queue so that handling of both McBSP callbacks and requests
+	// made to the LDD from user mode can be processed in the same thread, to avoid the use of semaphores
+	TInt r = Kern::DfcQCreate(iDfcQ, 26, &KAudioDFC);
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::PDD install");
+
+	if(r==KErrNone)
+		{
+		// All PDD factories must have a unique name
+		TInt r = SetName(&KSoundScPddName);
+		}
+
+	return r;
+	}
+
+void DDriverSyborgSoundScPddFactory::GetCaps(TDes8& /*aDes*/) const
+	{
+	}
+
+
+TInt DDriverSyborgSoundScPddFactory::Validate(TInt aUnit, const TDesC8* /*aInfo*/, const TVersion& aVer)
+	{
+	// Check that the version requested is less than or equal to the version of this PDD
+	if (!Kern::QueryVersionSupported(RSoundSc::VersionRequired(), aVer))
+		{
+		SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::Validate KErrNotSup1");
+		return KErrNotSupported;
+		}
+
+	// Check the unit number specifies either playback or recording
+	if ((aUnit != KSoundScTxUnit0) && (aUnit != KSoundScRxUnit0))
+		{
+		SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::Validate KErrNotSup2");
+		return KErrNotSupported;
+		}
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::Validate KErrNone");
+	return KErrNone;
+	}
+
+TInt DDriverSyborgSoundScPddFactory::Create(DBase*& aChannel, TInt aUnit, const TDesC8* /*aInfo*/, const TVersion& /*aVer*/)
+	{
+
+	DSoundScPdd* pD = NULL;
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::PDD create aUnit %d TxUnitId %d", aUnit, KSoundScTxUnit0);
+
+	// Assume failure
+	TInt r = KErrNoMemory;
+	aChannel = NULL;
+
+				
+	DDriverSyborgSoundScPdd* pTxD = new DDriverSyborgSoundScPdd;
+
+	SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::TxPdd %d", pTxD);
+		
+	if (pTxD)
+		{
+		pD = pTxD;
+
+		// Save a pointer to the factory so that it is accessible by the PDD and call the PDD's
+		// second stage constructor
+		pTxD->iPhysicalDevice = this;
+			
+		pTxD->iUnitType = aUnit; // Either KSoundScTxUnit0 or KSoundScRxUnit0 (play or record)
+			
+		SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::TxPdd2 %d", pTxD);
+			
+		r = pTxD->DoCreate();
+			
+		SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::Create ret %d", r);
+			
+		}
+	
+	// If everything succeeded, save a pointer to the PDD.  This should only be done if DoCreate() succeeded,
+	// as some LDDs have been known to access this pointer even if Create() returns an error!
+	if (r == KErrNone)
+		{
+		aChannel = pD;
+		SYBORG_SOUND_DEBUG("DDriverSyborgSoundScPddFactory::TxPdd set AChannel %d", aChannel);
+		}
+	else
+		{
+		delete pD;
+		}
+
+	return r;
+	}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/baseport/syborg/soundsc/variant_sound.h	Thu Nov 12 09:14:36 2009 -0800
@@ -0,0 +1,40 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#ifndef __SYBORGVARIANT_SOUND_H__
+#define __SYBORGVARIANT_SOUND_H__
+
+#include "shared_sound.h"
+
+class DDriverSyborgSoundScPddFactory : public DPhysicalDevice
+	{
+public:
+
+	DDriverSyborgSoundScPddFactory();
+	TInt Install();
+	void GetCaps(TDes8 &aDes) const;
+	TInt Create(DBase*& aChannel, TInt aUnit, const TDesC8* anInfo, const TVersion &aVer);
+	TInt Validate(TInt aUnit, const TDesC8* anInfo, const TVersion &aVer);
+
+public:
+
+	/** The DFC queue to be used by both the LDD and the PDD to serialise access to the PDD */
+	TDfcQue*		iDfcQ;
+
+	};
+
+#endif 
--- a/baseport/syborg/specific/syborg.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/specific/syborg.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -27,7 +27,7 @@
 
 void TSyborg::Init3()
 {
-//  SetTimerMode(KHwBaseCounterTimer, ETimerModePeriodic); 
+//  SetTimerMode(KHwBaseCounterTimer, ETimerModePeriodic);
 //  EnableTimer(KHwBaseCounterTimer, EEnable);
 }
 
@@ -105,10 +105,12 @@
 
 EXPORT_C TInt TSyborg::VideoRamSize()
 {
-  return 4*640*480;
+
+  return 4*854*854; // Now allow for 854 x 854 display, instead of 480 x 640
+
 }
 
-// !@! 
+// !@!
 EXPORT_C TPhysAddr TSyborg::VideoRamPhys()
 {
 #if 0
--- a/baseport/syborg/svphostfs/driver/svphostfsdriver.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/svphostfs/driver/svphostfsdriver.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -416,7 +416,14 @@
 	
 	if (KErrNone != err)
 		{
-		DP("Error %d from DoRequest", err);
+
+		if (err == KErrNotSupported)
+			{
+			err = KErrNone; // trap KErrNotSupported
+			}
+				
+		DP("Error %d from DoRequest %d", err, aReqNo);
+
 		}
 	
 	return err;
@@ -437,6 +444,12 @@
 
 	if (KErrNone != err)
 		{
+
+		if (err == KErrNotSupported)
+			{
+			err = KErrNone; // trap KErrNotSupported
+			}
+
 		DP("** (SVPHOSTFSDRIVER) Error %d from control function", err);
 		}
 	
@@ -501,7 +514,16 @@
 	SVPWriteReg(device, EArg2, info.iFlags);
 	SVPInvoke(device, RSVPHostFsDriver::EMkDir);
 
-	return SVPReadReg(device, EResult);
+
+	//return SVPReadReg(device, EResult);
+	
+	err = SVPReadReg(device, EResult);
+	
+	if(err == KErrPathNotFound)
+		err = KErrNotFound;
+	
+	return err;
+
 
 	}
 
@@ -637,7 +659,20 @@
 	SVPWriteReg(device, EArg1, info.iLength);
 	SVPInvoke(device, RSVPHostFsDriver::EEntry);
 
-	RET_IF_ERROR(err, SVPReadReg(device, EResult));
+
+	//RET_IF_ERROR(err, SVPReadReg(device, EResult));
+	
+	err = SVPReadReg(device, EResult);
+	
+	if(err!=KErrNone)
+		{
+		if(err == KErrPathNotFound)
+			err = KErrNotFound;
+		
+		return err;
+		}
+
+	
 
 	TUint32 att = SVPReadReg(device, EArg0);
 	TUint32 modified = SVPReadReg(device, EArg1);
@@ -690,7 +725,20 @@
 	SVPWriteReg(device, EArg1, info.iLength);
 	SVPInvoke(device, RSVPHostFsDriver::EDirOpen);
 
-	RET_IF_ERROR(err, SVPReadReg(device, EResult));
+
+	//RET_IF_ERROR(err, SVPReadReg(device, EResult));
+	
+	err = SVPReadReg(device, EResult);
+	
+	if(err!=KErrNone)
+		{
+		
+		if(err==KErrPathNotFound)
+			err=KErrNotFound;
+		
+		return err;
+		}
+
 
 	// handle is in arg 0
 	TUint32 handle = SVPReadReg(device, EArg0);
@@ -719,7 +767,20 @@
 	SVPWriteReg(device, EArg3, info.iOpen);
 	SVPInvoke(device, RSVPHostFsDriver::EFileOpen);
 
-	RET_IF_ERROR(err, SVPReadReg(device, EResult));
+
+	//RET_IF_ERROR(err, SVPReadReg(device, EResult));
+	
+	err = SVPReadReg(device, EResult);
+		
+	if(err!=KErrNone)
+		{
+		if(err == KErrPathNotFound)
+			err = KErrNotFound;
+		
+		return err;
+		}
+
+	
 
 	TUint32 handle = SVPReadReg(device, EArg0);
 	TUint32 att = SVPReadReg(device, EArg1);
@@ -797,7 +858,20 @@
 	SVPWriteReg(device, EArg3, info.iLength);	
 	SVPInvoke(device, RSVPHostFsDriver::EFileWrite);
 
-	RET_IF_ERROR(err, SVPReadReg(device, EResult));
+
+	// RET_IF_ERROR(err, SVPReadReg(device, EResult));
+	
+	err = SVPReadReg(device, EResult);
+	
+	if(err!=KErrNone)
+		{
+		if(err == KErrPathNotFound)
+			err = KErrNotFound;
+		
+		return err;
+		}
+
+	
 
 	TUint32 len = SVPReadReg(device, EArg0);
 
@@ -831,7 +905,9 @@
 	{
         DP("** (SVPHOSTFSDRIVER) DSVPHostFsChannel::FileSetEntry()");
 
-	return KErrNotSupported;
+
+	return KErrNone;
+
 	}
 
 TInt DSVPHostFsChannel::DirClose(TUint32 aDrive, TUint32 aHandle)
--- a/baseport/syborg/svphostfs/fs/rsvphostfsdriver.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/svphostfs/fs/rsvphostfsdriver.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -10,6 +10,7 @@
 * Nokia Corporation - initial contribution.
 *
 * Contributors:
+* Sosco - bug fixes
 *
 * Description:
 *
@@ -92,6 +93,19 @@
 TInt RSVPHostFsDriver::FileClose(TUint32 aDrive, TUint32 aHandle)
 	{
 	DP(_L("** (rsvphostfsdriver.cpp) RSVPHostFsDriver::FileClose()"));
+
+	// If attempt is made to access a file which does
+	// not exist, it will not give a handle to close afterwards.
+	// Attempting to call FileClose on this with an invalid handle
+	// results in the error code KErrBadHandle (-8) being returned.
+	// Some UI's cannot cope properly with this error code, resulting
+	// in various servers repeatedly closing and reopening. To prevent
+	// this,we trap it here and return KErrNone as though the call
+	// completed properly without error.
+	if (aHandle == 0)  
+	  return KErrNone; // Bad handle, so exit immediately with KErrNone
+	else
+
 	return DoSVPRequest(EFileClose, (TAny *)aDrive, (TAny *)aHandle);
 	}
 
@@ -140,6 +154,20 @@
 TInt RSVPHostFsDriver::DirClose(TUint32 aDrive, TUint32 aHandle)
 	{
 	DP(_L("** (rsvphostfsdriver.cpp) RSVPHostFsDriver::DirClose()"));
+
+
+	// If attempt is made to read a directory which does
+	// not exist, it will not give a handle to close afterwards.
+	// Attempting to call DirClose on this with an invalid handle
+	// results in the error code KErrBadHandle (-8) being returned.
+	// Some UI's cannot cope properly with this error code, resulting
+	// in various servers repeatedly closing and reopening. To prevent
+	// this,we trap it here and return KErrNone as though the call
+	// completed properly without error.
+	if (aHandle == 0)  
+	  return KErrNone; // Bad handle, so exit immediately with KErrNone
+	else
+
 	return DoSVPRequest(EDirClose, (TAny *)aDrive, (TAny *)aHandle);
 	}
 
--- a/baseport/syborg/svphostfs/fs/svphostdir.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/svphostfs/fs/svphostdir.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -116,9 +116,14 @@
 			}
 		iPending=EFalse;
 		anEntry=iEntry;
-		if ((iFullName.NameAndExt()==_L("*.*") || anEntry.iName.MatchF(iFullName.NameAndExt())!=KErrNotFound) 
-		    && Mount().MatchEntryAtt(anEntry.iAtt&KEntryAttMaskSupported,iAtt))
-			{
+
+
+		if (Mount().MatchEntryAtt(anEntry.iAtt&KEntryAttMaskSupported,iAtt) == EFalse)
+			continue;
+
+		if (iFullName.NameAndExt()==_L("*.*") || anEntry.iName.MatchF(iFullName.NameAndExt())!=KErrNotFound) 
+
+   			{
 			if (MatchUid())
 				{
 				TParse fileName;
--- a/baseport/syborg/svphostfs/fs/svphostmnt.cpp	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/svphostfs/fs/svphostmnt.cpp	Thu Nov 12 09:14:36 2009 -0800
@@ -23,7 +23,11 @@
 #include "svphostfsy.h"
 
 #define HOST_SVP_DRIVE_SIZE 1024*1024*1024
-#define HOST_SVP_DRIVE_FREE_SIZE 10*1024*1024
+
+// Fixed low mass-memory warning at startup
+//#define HOST_SVP_DRIVE_FREE_SIZE 10*1024*1024
+#define HOST_SVP_DRIVE_FREE_SIZE 100*1024*1024
+
 
 LOCAL_C TInt GetMediaSize(TInt /*aDriveNumber*/,TInt64& aSize,TInt64& aFree)
 //
--- a/baseport/syborg/syborg.oby	Mon Nov 09 09:51:45 2009 +0000
+++ b/baseport/syborg/syborg.oby	Thu Nov 12 09:14:36 2009 -0800
@@ -35,7 +35,11 @@
 define VARIANT			syborg
 define VARID			SYBORG_L1
 define ASSP_DIR			EPOCROOT##epoc32\release\syborg
-define ROMMEGS			15		/* !! HEX !! */
+
+// increased size of ROM, due to overflow
+//define ROMMEGS			15		/* !! HEX !! */
+
+define ROMMEGS			50		/* !! HEX !! */
 define PLATFORM_NAME		syborg
 
 #define COLOR
@@ -50,7 +54,9 @@
 define BLUETOOTH_ESK bt_port2.esk
 
 REM Define whether or not to include USB client support:
-//#define EUSBC
+
+#define EUSBC
+
 
 ROMBUILD_OPTION -no-header