mirror of
				https://github.com/acidanthera/audk.git
				synced 2025-10-26 01:33:45 +02:00 
			
		
		
		
	1. change *.msa to *.inf, and create platform configuration files .dec&.dsc&.fdf to comply with Edk2 build process 2. using PCD mechanism to replace macro. 3. change Sec code to cowork with PI1.0 Pei Core and produce temparory memory ppi. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5380 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			267 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			267 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*++
 | |
|  
 | |
| Copyright (c) 2006, Intel Corporation                                                         
 | |
| All rights reserved. This program and the accompanying materials                          
 | |
| are licensed and made available under the terms and conditions of the BSD License         
 | |
| which accompanies this distribution.  The full text of the license may be found at        
 | |
| http://opensource.org/licenses/bsd-license.php                                            
 | |
|                                                                                           
 | |
| THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
 | |
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             
 | |
| 
 | |
| Module Name:
 | |
| 
 | |
|   MiscPortInternalConnectorDesignatorFunction.c
 | |
|   
 | |
| Abstract: 
 | |
| 
 | |
|   This driver parses the mMiscSubclassDataTable structure and reports
 | |
|   any generated data to the DataHub.
 | |
| 
 | |
| --*/
 | |
| 
 | |
| #include "MiscSubClassDriver.h"
 | |
| 
 | |
| //
 | |
| //
 | |
| //
 | |
| MISC_SUBCLASS_TABLE_FUNCTION (
 | |
|   MiscPortInternalConnectorDesignator
 | |
|   )
 | |
| /*++
 | |
| Description:
 | |
| 
 | |
|   This function makes boot time changes to the contents of the
 | |
|   MiscPortConnectorInformation (Type 8).
 | |
| 
 | |
| Parameters:
 | |
| 
 | |
|   RecordType
 | |
|     Type of record to be processed from the Data Table.
 | |
|     mMiscSubclassDataTable[].RecordType
 | |
| 
 | |
|   RecordLen
 | |
|     Size of static RecordData from the Data Table.
 | |
|     mMiscSubclassDataTable[].RecordLen
 | |
| 
 | |
|   RecordData
 | |
|     Pointer to copy of RecordData from the Data Table.  Changes made
 | |
|     to this copy will be written to the Data Hub but will not alter
 | |
|     the contents of the static Data Table.
 | |
| 
 | |
|   LogRecordData
 | |
|     Set *LogRecordData to TRUE to log RecordData to Data Hub.
 | |
|     Set *LogRecordData to FALSE when there is no more data to log.
 | |
| 
 | |
| Returns:
 | |
| 
 | |
|   EFI_SUCCESS
 | |
|     All parameters were valid and *RecordData and *LogRecordData have
 | |
|     been set.
 | |
| 
 | |
|   EFI_UNSUPPORTED
 | |
|     Unexpected RecordType value.
 | |
| 
 | |
|   EFI_INVALID_PARAMETER
 | |
|     One of the following parameter conditions was true:
 | |
|       RecordLen was zero.
 | |
|       RecordData was NULL.
 | |
|       LogRecordData was NULL.
 | |
| --*/
 | |
| {
 | |
|   STATIC BOOLEAN                    Done                    = FALSE;
 | |
|   STATIC PS2_CONN_DEVICE_PATH       mPs2KeyboardDevicePath  = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0303, 0), DP_END };
 | |
|   STATIC PS2_CONN_DEVICE_PATH       mPs2MouseDevicePath     = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0303, 1), DP_END };
 | |
|   STATIC SERIAL_CONN_DEVICE_PATH    mCom1DevicePath         = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0501, 0), DP_END };
 | |
|   STATIC SERIAL_CONN_DEVICE_PATH    mCom2DevicePath         = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0501, 1), DP_END };
 | |
|   //STATIC PARALLEL_CONN_DEVICE_PATH  mLpt1DevicePath         = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0401, 0), DP_END };
 | |
|   STATIC FLOOPY_CONN_DEVICE_PATH    mFloopyADevicePath      = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0604, 0), DP_END };
 | |
|   //STATIC FLOOPY_CONN_DEVICE_PATH    mFloopyBDevicePath      = { DP_ACPI, DP_PCI (0x1F, 0x00), DP_LPC (0x0604, 1), DP_END };
 | |
|   //STATIC USB_PORT_DEVICE_PATH       mUsb0DevicePath         = { DP_ACPI, DP_PCI (0x1d, 0x00), DP_END };
 | |
|   //STATIC USB_PORT_DEVICE_PATH       mUsb1DevicePath         = { DP_ACPI, DP_PCI (0x1d, 0x01), DP_END };
 | |
|   //STATIC USB_PORT_DEVICE_PATH       mUsb2DevicePath         = { DP_ACPI, DP_PCI (0x1d, 0x02), DP_END };
 | |
|   //STATIC USB_PORT_DEVICE_PATH       mUsb3DevicePath         = { DP_ACPI, DP_PCI (0x1d, 0x07), DP_END };
 | |
|   //STATIC IDE_DEVICE_PATH            mIdeDevicePath          = { DP_ACPI, DP_PCI (0x1F, 0x01), DP_END };
 | |
|   //STATIC GB_NIC_DEVICE_PATH         mGbNicDevicePath        = { DP_ACPI, DP_PCI( 0x03,0x00 ),DP_PCI( 0x1F,0x00 ),DP_PCI( 0x07,0x00 ), DP_END };
 | |
|   EFI_DEVICE_PATH_PROTOCOL          EndDevicePath           = DP_END;
 | |
| 
 | |
|   //
 | |
|   // First check for invalid parameters.
 | |
|   //
 | |
|   // Shanmu >> to fix the Device Path Issue...
 | |
|   // if (RecordLen == 0 || RecordData == NULL || LogRecordData == NULL) {
 | |
|   //
 | |
|   if (*RecordLen == 0 || RecordData == NULL || LogRecordData == NULL) {
 | |
|     //
 | |
|     // End Shanmu
 | |
|     //
 | |
|     return EFI_INVALID_PARAMETER;
 | |
|   }
 | |
|   //
 | |
|   // Then check for unsupported RecordType.
 | |
|   //
 | |
|   if (RecordType != EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_RECORD_NUMBER) {
 | |
|     return EFI_UNSUPPORTED;
 | |
|   }
 | |
|   //
 | |
|   // Is this the first time through this function?
 | |
|   //
 | |
|   if (!Done) {
 | |
|     //
 | |
|     // Yes, this is the first time.  Inspect/Change the contents of the
 | |
|     // RecordData structure.
 | |
|     //
 | |
|     //
 | |
|     // Device path is only updated here as it was not taking that in static data
 | |
|     //
 | |
|     // Shanmu >> to fix the Device Path Issue...
 | |
|     //
 | |
| 
 | |
|     /*
 | |
|     switch (((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortInternalConnectorDesignator) 
 | |
|     {
 | |
|       case STR_MISC_PORT_INTERNAL_MOUSE:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mPs2MouseDevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_KEYBOARD:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mPs2KeyboardDevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_COM1:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mCom1DevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_COM2:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mCom2DevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_LPT1:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mLpt1DevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_USB1:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mUsb0DevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_USB2:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mUsb1DevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_USB3:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mUsb2DevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_NETWORK:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mGbNicDevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_FLOPPY:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mFloopyADevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_IDE1:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mIdeDevicePath);          
 | |
|         }break;
 | |
|       case STR_MISC_PORT_INTERNAL_IDE2:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = *((EFI_DEVICE_PATH_PROTOCOL*)&mIdeDevicePath);          
 | |
|         }break;
 | |
|       default:
 | |
|         {
 | |
|           (EFI_DEVICE_PATH_PROTOCOL)((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *)RecordData)->PortPath = EndDevicePath;
 | |
|         }break;    
 | |
|     }
 | |
|     */
 | |
|     switch (((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortInternalConnectorDesignator) {
 | |
|     case STR_MISC_PORT_INTERNAL_MOUSE:
 | |
|       {
 | |
|         CopyMem (
 | |
|           &((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortPath,
 | |
|           &mPs2MouseDevicePath,
 | |
|           GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mPs2MouseDevicePath)
 | |
|           );
 | |
|         *RecordLen = *RecordLen - sizeof (EFI_MISC_PORT_DEVICE_PATH) + GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mPs2MouseDevicePath);
 | |
|       }
 | |
|       break;
 | |
| 
 | |
|     case STR_MISC_PORT_INTERNAL_KEYBOARD:
 | |
|       {
 | |
|         CopyMem (
 | |
|           &((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortPath,
 | |
|           &mPs2KeyboardDevicePath,
 | |
|           GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mPs2KeyboardDevicePath)
 | |
|           );
 | |
|         *RecordLen = *RecordLen - sizeof (EFI_MISC_PORT_DEVICE_PATH) + GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mPs2KeyboardDevicePath);
 | |
|       }
 | |
|       break;
 | |
| 
 | |
|     case STR_MISC_PORT_INTERNAL_COM1:
 | |
|       {
 | |
|         CopyMem (
 | |
|           &((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortPath,
 | |
|           &mCom1DevicePath,
 | |
|           GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mCom1DevicePath)
 | |
|           );
 | |
|         *RecordLen = *RecordLen - sizeof (EFI_MISC_PORT_DEVICE_PATH) + GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mCom1DevicePath);
 | |
|       }
 | |
|       break;
 | |
| 
 | |
|     case STR_MISC_PORT_INTERNAL_COM2:
 | |
|       {
 | |
|         CopyMem (
 | |
|           &((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortPath,
 | |
|           &mCom2DevicePath,
 | |
|           GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mCom2DevicePath)
 | |
|           );
 | |
|         *RecordLen = *RecordLen - sizeof (EFI_MISC_PORT_DEVICE_PATH) + GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mCom2DevicePath);
 | |
|       }
 | |
|       break;
 | |
| 
 | |
|     case STR_MISC_PORT_INTERNAL_FLOPPY:
 | |
|       {
 | |
|         CopyMem (
 | |
|           &((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortPath,
 | |
|           &mFloopyADevicePath,
 | |
|           GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mFloopyADevicePath)
 | |
|           );
 | |
|         *RecordLen = *RecordLen - sizeof (EFI_MISC_PORT_DEVICE_PATH) + GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &mFloopyADevicePath);
 | |
|       }
 | |
|       break;
 | |
| 
 | |
|     default:
 | |
|       {
 | |
|         CopyMem (
 | |
|           &((EFI_MISC_PORT_INTERNAL_CONNECTOR_DESIGNATOR_DATA *) RecordData)->PortPath,
 | |
|           &EndDevicePath,
 | |
|           GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &EndDevicePath)
 | |
|           );
 | |
|         *RecordLen = *RecordLen - sizeof (EFI_MISC_PORT_DEVICE_PATH) + GetDevicePathSize ((EFI_DEVICE_PATH_PROTOCOL *) &EndDevicePath);
 | |
|       }
 | |
|       break;
 | |
|     }
 | |
|     //
 | |
|     // End Shanmu
 | |
|     //
 | |
|     // Set Done flag to TRUE for next pass through this function.
 | |
|     // Set *LogRecordData to TRUE so data will get logged to Data Hub.
 | |
|     //
 | |
|     Done            = TRUE;
 | |
|     *LogRecordData  = TRUE;
 | |
|   } else {
 | |
|     //
 | |
|     // No, this is the second time.  Reset the state of the Done flag
 | |
|     // to FALSE and tell the data logger that there is no more data
 | |
|     // to be logged for this record type.  If any memory allocations
 | |
|     // were made by earlier passes, they must be released now.
 | |
|     //
 | |
|     Done            = FALSE;
 | |
|     *LogRecordData  = FALSE;
 | |
|   }
 | |
| 
 | |
|   return EFI_SUCCESS;
 | |
| }
 | |
| 
 | |
| /* eof - MiscSystemManufacturerFunction.c */
 |