[59530] | 1 | ; $Id: ASMSerializeInstruction-rdtscp.asm 98103 2023-01-17 14:15:46Z vboxsync $
|
---|
| 2 | ;; @file
|
---|
| 3 | ; IPRT - ASMSerializeInstruction() using rdtscp.
|
---|
| 4 | ;
|
---|
| 5 |
|
---|
| 6 | ;
|
---|
[98103] | 7 | ; Copyright (C) 2006-2023 Oracle and/or its affiliates.
|
---|
[59530] | 8 | ;
|
---|
[96407] | 9 | ; This file is part of VirtualBox base platform packages, as
|
---|
| 10 | ; available from https://www.virtualbox.org.
|
---|
[59530] | 11 | ;
|
---|
[96407] | 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 | ;
|
---|
[59530] | 25 | ; The contents of this file may alternatively be used under the terms
|
---|
| 26 | ; of the Common Development and Distribution License Version 1.0
|
---|
[96407] | 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
|
---|
[59530] | 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 | ;
|
---|
[96407] | 34 | ; SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
|
---|
| 35 | ;
|
---|
[59530] | 36 |
|
---|
| 37 |
|
---|
| 38 | ;*******************************************************************************
|
---|
| 39 | ;* Header Files *
|
---|
| 40 | ;*******************************************************************************
|
---|
| 41 | %include "iprt/asmdefs.mac"
|
---|
| 42 |
|
---|
| 43 | BEGINCODE
|
---|
| 44 |
|
---|
| 45 |
|
---|
| 46 | ;;
|
---|
[92799] | 47 | ; Executes a serializing instruction.
|
---|
[59530] | 48 | ;
|
---|
| 49 | ; The RDTSCP instruction is fast, though it may trigger a VM EXIT if the VMM
|
---|
| 50 | ; is intercepting TSC reads for some timing reason or in general.
|
---|
| 51 | ;
|
---|
[92799] | 52 | RT_BEGINPROC ASMSerializeInstructionRdTscp
|
---|
[59530] | 53 | rdtscp
|
---|
| 54 | ret
|
---|
[92799] | 55 | ENDPROC ASMSerializeInstructionRdTscp
|
---|
[59530] | 56 |
|
---|