C++程序  |  98行  |  3.81 KB

/*++

  Copyright (c) 2004  - 2014, Intel Corporation. All rights reserved.<BR>
                                                                                   

  This program and the accompanying materials are licensed and made available under

  the terms and conditions of the BSD License that 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:

  LpcWpc83667Policy.h

Abstract:

  Protocol used for WPC83627 Policy definition.
-------------------------------------------------------------------------------
   Rev   Date<MM/DD/YYYY>    Name    Description
  -------------------------------------------------------------------------------
  R01   < 4/22/2011>         LB     Update driver for Sio83627UGH support.
  -------------------------------------------------------------------------------
**/

#ifndef _WPC83627_POLICY_PROTOCOL_H_
#define _WPC83627_POLICY_PROTOCOL_H_

EFI_FORWARD_DECLARATION (EFI_WPC83627_POLICY_PROTOCOL);

#define EFI_WPC83627_POLICY_PROTOCOL_GUID \
  { \
    0xd3ecc567, 0x9fd5, 0x44c1, 0x86, 0xcf, 0x5d, 0xa7, 0xa2, 0x4f, 0x4b, 0x5d \
  }

#define EFI_WPC83627_COM1_ENABLE          0x01
#define EFI_WPC83627_COM2_ENABLE          0x01

#define EFI_WPC83627_COM3_ENABLE          0x01
#define EFI_WPC83627_COM4_ENABLE          0x01

#define EFI_WPC83627_LPT1_ENABLE          0x01
#define EFI_WPC83627_LPT1_ENABLE          0x01
#define EFI_WPC83627_FDD_ENABLE           0x01
#define EFI_WPC83627_FDD_WRITE_ENABLE     0x01
#define EFI_WPC83627_PS2_KBC_ENABLE       0x01
#define EFI_WPC83627_ECIR_ENABLE	  0x01

#define EFI_WPC83627_COM1_DISABLE         0x00
#define EFI_WPC83627_COM2_DISABLE         0x00

#define EFI_WPC83627_COM3_DISABLE         0x00
#define EFI_WPC83627_COM4_DISABLE         0x00

#define EFI_WPC83627_LPT1_DISABLE         0x00
#define EFI_WPC83627_FDD_DISABLE          0x00
#define EFI_WPC83627_FDD_WRITE_PROTECT    0x00
#define EFI_WPC83627_PS2_KBC_DISABLE      0x00
#define EFI_WPC83627_ECIR_DISABLE         0x00
#define EFI_WPC83627_RESERVED_DEFAULT     0x00

typedef struct {
  UINT16  Com1               :1;             // 0 = Disable, 1 = Enable
  UINT16  Lpt1               :1;             // 0 = Disable, 1 = Enable
  UINT16  Floppy             :1;             // 0 = Disable, 1 = Enable
  UINT16  FloppyWriteProtect :1;             // 0 = Write Protect, 1 = Write Enable
  UINT16  Port80             :1;             // 0 = Disable, 1 = Enable
  UINT16  CIR                :1;             // CIR enable or disable
  UINT16  Ps2Keyboard        :1;             // 0 = Disable, 1 = Enable
  UINT16  Ps2Mouse           :1;             // 0 = Disable, 1 = Enable
  UINT16  Com2               :1;             // 0 = Disable, 1 = Enable

  UINT16  Com3               :1;             // 0 = Disable, 1 = Enable
  UINT16  Com4               :1;             // 0 = Disable, 1 = Enable

  UINT16  Dac                :1;             // 0 = Disable, 1 = Enable
  UINT16  Rsvd               :6;
} EFI_WPC83627_DEVICE_ENABLES;

typedef enum {
  LptModeOutput,
  LptModeBiDirectional,
  LptModeEpp,
  LptModeEcp
} EFI_LPT_MODE;

typedef struct _EFI_WPC83627_POLICY_PROTOCOL {
  EFI_WPC83627_DEVICE_ENABLES DeviceEnables;
  EFI_LPT_MODE              LptMode;
} EFI_WPC83627_POLICY_PROTOCOL;

extern EFI_GUID gEfiLpcWpc83627PolicyProtocolGuid;

#endif