VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-cmn-MemCmp.asm@ 77922

Last change on this file since 77922 was 76553, checked in by vboxsync, 6 years ago

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.7 KB
Line 
1; $Id: bs3-cmn-MemCmp.asm 76553 2019-01-01 01:45:53Z vboxsync $
2;; @file
3; BS3Kit - Bs3MemCmp.
4;
5
6;
7; Copyright (C) 2007-2019 Oracle Corporation
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17; The contents of this file may alternatively be used under the terms
18; of the Common Development and Distribution License Version 1.0
19; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20; VirtualBox OSE distribution, in which case the provisions of the
21; CDDL are applicable instead of those of the GPL.
22;
23; You may elect to license modified versions of this file under the
24; terms and conditions of either the GPL or the CDDL or both.
25;
26
27%include "bs3kit-template-header.mac"
28
29;;
30; @cproto BS3_CMN_PROTO_NOSB(int, Bs3MemCmp,(void const BS3_FAR *pv1, void const BS3_FAR *pv2, size_t cb));
31;
32BS3_PROC_BEGIN_CMN Bs3MemCmp, BS3_PBC_HYBRID
33TONLY16 CPU 8086
34 push xBP
35 mov xBP, xSP
36 push xDI
37 push xSI
38TNOT64 push es
39TONLY16 push ds
40 cld
41
42 ;
43 ; To save complexity and space, do straight forward byte compares.
44 ;
45%if TMPL_BITS == 16
46 mov di, [bp + 2 + cbCurRetAddr] ; pv1.off
47 mov es, [bp + 2 + cbCurRetAddr + 2] ; pv1.sel
48 mov si, [bp + 2 + cbCurRetAddr + 4] ; pv2.off
49 mov ds, [bp + 2 + cbCurRetAddr + 6] ; pv2.sel
50 mov cx, [bp + 2 + cbCurRetAddr + 8] ; cbDst
51 xor ax, ax
52 repe cmpsb
53 je .return
54
55 mov al, [es:di - 1]
56 xor dx, dx
57 mov dl, [esi - 1]
58 sub ax, dx
59
60%else
61 %if TMPL_BITS == 64
62 mov rdi, rcx ; rdi = pv1
63 mov rsi, rdx ; rdi = pv2
64 mov rcx, r8 ; rcx = cbDst
65 %else
66 mov ax, ds
67 mov es, ax ; paranoia
68 mov edi, [ebp + 4 + cbCurRetAddr] ; pv1
69 mov esi, [ebp + 4 + cbCurRetAddr + 4] ; pv2
70 mov ecx, [ebp + 4 + cbCurRetAddr + 8] ; cbDst
71 %endif
72 xor eax, eax
73 repe cmpsb
74 je .return
75
76 mov al, [xDI - 1]
77 movzx edx, byte [xSI - 1]
78 sub eax, edx
79%endif
80
81.return:
82TONLY16 pop ds
83TNOT64 pop es
84 pop xSI
85 pop xDI
86 pop xBP
87 BS3_HYBRID_RET
88BS3_PROC_END_CMN Bs3MemCmp
89
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