;/** ; * @file ; * ; * Agesa library 32bit ; * ; * Contains AMD AGESA Library ; * ; * @xrefitem bom "File Content Label" "Release Content" ; * @e project: AGESA ; * @e sub-project: Lib ; * @e \$Revision: 17071 $ @e \$Date: 2009-07-30 10:13:11 -0700 (Thu, 30 Jul 2009) $ ; */ ;***************************************************************************** ; ; Copyright (c) 2011, Advanced Micro Devices, Inc. ; All rights reserved. ; ; Redistribution and use in source and binary forms, with or without ; modification, are permitted provided that the following conditions are met: ; * Redistributions of source code must retain the above copyright ; notice, this list of conditions and the following disclaimer. ; * Redistributions in binary form must reproduce the above copyright ; notice, this list of conditions and the following disclaimer in the ; documentation and/or other materials provided with the distribution. ; * Neither the name of Advanced Micro Devices, Inc. nor the names of ; its contributors may be used to endorse or promote products derived ; from this software without specific prior written permission. ; ; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ; ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED ; WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ; DISCLAIMED. IN NO EVENT SHALL ADVANCED MICRO DEVICES, INC. BE LIABLE FOR ANY ; DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES ; (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ; ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS ; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ; ;***************************************************************************** .586p .xmm .model flat,C ASSUME FS:NOTHING .code ;--------------------------------------------------------------------------- ; ; _mm_clflush_fs - execute clflush instruction for address fs:address32 ; this lets clflush operate beyond 4GB in 32-bit mode ; ; void _mm_clflush_fs (void *address32); ; _mm_clflush_fs proc public mov eax, [esp+8] clflush fs:[eax] ret _mm_clflush_fs ENDP ;--------------------------------------------------------------------------- ; ; _mm_stream_si128_fs - execute movntdq instruction for address fs:address32 ; this lets movntdq operate beyond 4GB in 32-bit mode ; ; void _mm_stream_si128_fs (void *dest, void *data) ; _mm_stream_si128_fs proc public push esi mov esi, [esp+12] movdqa xmm0, [esi] mov esi, [esp+8] movntdq fs:[esi], xmm0 pop esi ret _mm_stream_si128_fs ENDP ;--------------------------------------------------------------------------- END