VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-weird-1-template.mac@ 101672

Last change on this file since 101672 was 98103, checked in by vboxsync, 23 months ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.4 KB
Line 
1; $Id: bs3-cpu-weird-1-template.mac 98103 2023-01-17 14:15:46Z vboxsync $
2;; @file
3; BS3Kit - bs3-cpu-weird-1 assembly template.
4;
5
6;
7; Copyright (C) 2007-2023 Oracle and/or its affiliates.
8;
9; This file is part of VirtualBox base platform packages, as
10; available from https://www.virtualbox.org.
11;
12; This program is free software; you can redistribute it and/or
13; modify it under the terms of the GNU General Public License
14; as published by the Free Software Foundation, in version 3 of the
15; License.
16;
17; This program is distributed in the hope that it will be useful, but
18; WITHOUT ANY WARRANTY; without even the implied warranty of
19; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20; General Public License for more details.
21;
22; You should have received a copy of the GNU General Public License
23; along with this program; if not, see <https://www.gnu.org/licenses>.
24;
25; The contents of this file may alternatively be used under the terms
26; of the Common Development and Distribution License Version 1.0
27; (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
28; in the VirtualBox distribution, in which case the provisions of the
29; CDDL are applicable instead of those of the GPL.
30;
31; You may elect to license modified versions of this file under the
32; terms and conditions of either the GPL or the CDDL or both.
33;
34; SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
35;
36
37
38;*********************************************************************************************************************************
39;* Header Files *
40;*********************************************************************************************************************************
41%include "bs3kit-template-header.mac" ; setup environment
42
43
44;*********************************************************************************************************************************
45;* External Symbols *
46;*********************************************************************************************************************************
47TMPL_BEGIN_TEXT
48
49
50;
51; Test code snippets containing code which differs between 16-bit, 32-bit
52; and 64-bit CPUs modes.
53;
54%ifdef BS3_INSTANTIATING_CMN
55
56
57;
58; Inhibited int 80h.
59;
60BS3_PROC_BEGIN_CMN bs3CpuWeird1_InhibitedInt80, BS3_PBC_NEAR
61 ; Load SS from stack. This instruction causes fusing.
62%if TMPL_BITS != 64
63 pop ss
64%else
65 mov ss, [rsp]
66%endif
67 ; The ring transition instruction.
68BS3_GLOBAL_NAME_EX BS3_CMN_NM(bs3CpuWeird1_InhibitedInt80_int80), , 0
69 int 80h
70 ; We shouldn't get here!
71.ud2_again:
72 ud2
73 jmp .ud2_again
74BS3_PROC_END_CMN bs3CpuWeird1_InhibitedInt80
75
76;
77; Inhibited int 3.
78;
79BS3_PROC_BEGIN_CMN bs3CpuWeird1_InhibitedInt3, BS3_PBC_NEAR
80 ; Load SS from stack. This instruction causes fusing.
81%if TMPL_BITS != 64
82 pop ss
83%else
84 mov ss, [rsp]
85%endif
86 ; The ring transition instruction.
87BS3_GLOBAL_NAME_EX BS3_CMN_NM(bs3CpuWeird1_InhibitedInt3_int3), , 0
88 int 3
89 ; We shouldn't get here!
90.ud2_again:
91 ud2
92 jmp .ud2_again
93AssertCompile(.ud2_again - BS3_CMN_NM(bs3CpuWeird1_InhibitedInt3_int3) == 2)
94BS3_PROC_END_CMN bs3CpuWeird1_InhibitedInt3
95
96
97;
98; Inhibited int3.
99;
100BS3_PROC_BEGIN_CMN bs3CpuWeird1_InhibitedBp, BS3_PBC_NEAR
101 ; Load SS from stack. This instruction causes fusing.
102%if TMPL_BITS != 64
103 pop ss
104%else
105 mov ss, [rsp]
106%endif
107 ; The ring transition instruction.
108BS3_GLOBAL_NAME_EX BS3_CMN_NM(bs3CpuWeird1_InhibitedBp_int3), , 0
109 int3
110 ; We shouldn't get here!
111.ud2_again:
112 ud2
113 jmp .ud2_again
114AssertCompile(.ud2_again - BS3_CMN_NM(bs3CpuWeird1_InhibitedBp_int3) == 1)
115BS3_PROC_END_CMN bs3CpuWeird1_InhibitedBp
116
117
118;
119; PC (IP/EIP) wrapper templates.
120; These will potentially trigger VM exits, except for the benign one.
121;
122; Note! Single instructions as the testcase will shift multibyte variations
123; across the wrap-around boundary and that would cause unpredictable
124; results for the 16-bit if there is more than one instruction.
125;
126
127BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapBenign1, BS3_PBC_NEAR
128 nop
129BS3_PROC_END_CMN bs3CpuWeird1_PcWrapBenign1
130
131BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapBenign2, BS3_PBC_NEAR
132 xor xDX, xAX
133BS3_PROC_END_CMN bs3CpuWeird1_PcWrapBenign2
134
135BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapCpuId, BS3_PBC_NEAR
136 cpuid
137BS3_PROC_END_CMN bs3CpuWeird1_PcWrapCpuId
138
139BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapIn80, BS3_PBC_NEAR
140 in al, 80h
141BS3_PROC_END_CMN bs3CpuWeird1_PcWrapIn80
142
143BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapOut80, BS3_PBC_NEAR
144 out 80h, al
145BS3_PROC_END_CMN bs3CpuWeird1_PcWrapOut80
146
147BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapSmsw, BS3_PBC_NEAR
148 smsw si
149BS3_PROC_END_CMN bs3CpuWeird1_PcWrapSmsw
150
151BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapRdCr0, BS3_PBC_NEAR
152 mov sAX, cr0
153BS3_PROC_END_CMN bs3CpuWeird1_PcWrapRdCr0
154
155BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapRdDr0, BS3_PBC_NEAR
156 mov sAX, dr0
157BS3_PROC_END_CMN bs3CpuWeird1_PcWrapRdDr0
158
159BS3_PROC_BEGIN_CMN bs3CpuWeird1_PcWrapWrDr0, BS3_PBC_NEAR
160 mov dr0, sAX
161BS3_PROC_END_CMN bs3CpuWeird1_PcWrapWrDr0
162
163
164%endif ; BS3_INSTANTIATING_CMN
165
166%include "bs3kit-template-footer.mac" ; reset environment
167
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette