summaryrefslogtreecommitdiff
path: root/EdkModulePkg/Include/Protocol/GenericMemoryTest.h
blob: 8f566d3763f1e38631991330e9042e7bfb82f7f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
/*++

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:

    GenericMemoryTest.h

Abstract:

    The EFI generic memory test protocol
    For more information please look at EfiMemoryTest.doc

--*/

#ifndef __GENERIC_MEMORY_TEST_H__
#define __GENERIC_MEMORY_TEST_H__

#define EFI_GENERIC_MEMORY_TEST_PROTOCOL_GUID  \
  { 0x309de7f1, 0x7f5e, 0x4ace, {0xb4, 0x9c, 0x53, 0x1b, 0xe5, 0xaa, 0x95, 0xef} }

typedef struct _EFI_GENERIC_MEMORY_TEST_PROTOCOL  EFI_GENERIC_MEMORY_TEST_PROTOCOL;

typedef enum {
  IGNORE,
  QUICK,
  SPARSE,
  EXTENSIVE,
  MAXLEVEL
} EXTENDMEM_COVERAGE_LEVEL;

typedef
EFI_STATUS
(EFIAPI *EFI_MEMORY_TEST_INIT) (
  IN EFI_GENERIC_MEMORY_TEST_PROTOCOL *This,
  IN  EXTENDMEM_COVERAGE_LEVEL                 Level,
  OUT BOOLEAN                                  *RequireSoftECCInit
  )
/*++

  Routine Description:
    Initialize the generic memory test.

  Arguments:
    This                  - Protocol instance pointer.
    Level                 - The coverage level of the memory test.
    RequireSoftECCInit    - Indicate if the memory need software ECC init.

  Returns:
    EFI_SUCCESS           - The generic memory test initialized correctly.
    EFI_NO_MEDIA          - There is not any non-tested memory found, in this
                            function if not any non-tesed memory found means 
                            that the memory test driver have not detect any
                            non-tested extended memory of current system.

--*/
;

typedef
EFI_STATUS
(EFIAPI *EFI_PERFORM_MEMORY_TEST) (
  IN EFI_GENERIC_MEMORY_TEST_PROTOCOL *This,
  OUT UINT64                                   *TestedMemorySize,
  OUT UINT64                                   *TotalMemorySize,
  OUT BOOLEAN                                  *ErrorOut,
  IN BOOLEAN                                   IfTestAbort
  )
/*++

  Routine Description:
    Perform the memory test.

  Arguments:
    This                  - Protocol instance pointer.
    TestedMemorySize      - Return the tested extended memory size.
    TotalMemorySize       - Return the whole system physical memory size, this 
                            value may be changed if in some case some error 
                            DIMMs be disabled.
    ErrorOut              - Any time the memory error occurs, this will be TRUE.
    IfTestAbort           - Indicate if the user press "ESC" to skip the memory
                            test.

  Returns:
    EFI_SUCCESS           - One block of memory test ok, the block size is hide
                            internally.
    EFI_NOT_FOUND         - Indicate all the non-tested memory blocks have 
                            already go through.

--*/
;

typedef
EFI_STATUS
(EFIAPI *EFI_MEMORY_TEST_FINISHED) (
  IN EFI_GENERIC_MEMORY_TEST_PROTOCOL *This
  )
/*++

  Routine Description:
    The memory test finished.

  Arguments:
    This                  - Protocol instance pointer.

  Returns:
    EFI_SUCCESS           - Successful free all the generic memory test driver
                            allocated resource and notify to platform memory
                            test driver that memory test finished.

--*/
;
  
typedef
EFI_STATUS
(EFIAPI *EFI_MEMORY_TEST_COMPATIBLE_RANGE) (
  IN EFI_GENERIC_MEMORY_TEST_PROTOCOL *This,
  IN  EFI_PHYSICAL_ADDRESS                     StartAddress,
  IN  UINT64                                   Length
  )
/*++
  
  Routine Description:
    Provide capability to test compatible range which used by some sepcial
    driver required using memory range before BDS perform memory test.
    
  Arguments:
    This                  - Protocol instance pointer.
    StartAddress          - The start address of the memory range.
    Length                - The memory range's length.
    
  Return:
    EFI_SUCCESS           - The compatible memory range pass the memory test.
    EFI_DEVICE_ERROR      - The compatible memory range test find memory error
                            and also return return the error address.
    
--*/
;

struct _EFI_GENERIC_MEMORY_TEST_PROTOCOL {
  EFI_MEMORY_TEST_INIT              MemoryTestInit;
  EFI_PERFORM_MEMORY_TEST           PerformMemoryTest;
  EFI_MEMORY_TEST_FINISHED          Finished;
  EFI_MEMORY_TEST_COMPATIBLE_RANGE  CompatibleRangeTest;
};

extern EFI_GUID gEfiGenericMemTestProtocolGuid;

#endif