]> git.proxmox.com Git - mirror_edk2.git/blame - MdePkg/Library/BaseLib/Ia32/CpuIdEx.S
Minor grammatical work--mostly adding periods. Sending separately a list of files...
[mirror_edk2.git] / MdePkg / Library / BaseLib / Ia32 / CpuIdEx.S
CommitLineData
b1ff428c 1#------------------------------------------------------------------------------\r
2#\r
bb817c56
HT
3# Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>\r
4# This program and the accompanying materials\r
b1ff428c 5# are licensed and made available under the terms and conditions of the BSD License\r
6# which accompanies this distribution. The full text of the license may be found at\r
35a17154 7# http://opensource.org/licenses/bsd-license.php.\r
b1ff428c 8#\r
9# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
10# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
11#\r
12# Module Name:\r
13#\r
14# CpuIdEx.S\r
15#\r
16# Abstract:\r
17#\r
18# AsmCpuidEx function\r
19#\r
20# Notes:\r
21#\r
22#------------------------------------------------------------------------------\r
23\r
24 .686:\r
25 .code:\r
26\r
27#------------------------------------------------------------------------------\r
28# UINT32\r
29# EFIAPI\r
30# AsmCpuidEx (\r
31# IN UINT32 RegisterInEax,\r
32# IN UINT32 RegisterInEcx,\r
33# OUT UINT32 *RegisterOutEax OPTIONAL,\r
34# OUT UINT32 *RegisterOutEbx OPTIONAL,\r
35# OUT UINT32 *RegisterOutEcx OPTIONAL,\r
36# OUT UINT32 *RegisterOutEdx OPTIONAL\r
37# )\r
38#------------------------------------------------------------------------------\r
132f41f0 39ASM_GLOBAL ASM_PFX(AsmCpuidEx)\r
b1ff428c 40ASM_PFX(AsmCpuidEx):\r
41 push %ebx\r
42 push %ebp\r
43 movl %esp, %ebp\r
44 movl 12(%ebp), %eax\r
45 movl 16(%ebp), %ecx\r
46 cpuid\r
47 push %ecx\r
48 movl 20(%ebp), %ecx\r
49 jecxz L1\r
50 movl %eax, (%ecx)\r
51L1:\r
52 movl 24(%ebp), %ecx\r
53 jecxz L2\r
54 movl %ebx, (%ecx)\r
55L2:\r
56 movl 28(%ebp), %ecx\r
57 jecxz L3\r
58 popl (%ecx)\r
59L3:\r
60 movl 32(%ebp), %edx\r
61 jecxz L4\r
62 movl %edx, (%ecx)\r
63L4:\r
64 movl 12(%ebp), %eax\r
65 leave\r
66 pop %ebx\r
67 ret\r