📄 nrv2d_d8.s
字号:
/*; n2d_d8e.ash -- ucl_nrv2d_decompress_8 in 16-bit assembly (dos/exe);; This file is part of the UCL data compression library.;; Copyright (C) 1996-2007 Markus Franz Xaver Johannes Oberhumer; All Rights Reserved.;; The UCL library is free software; you can redistribute it and/or; modify it under the terms of the GNU General Public License as; published by the Free Software Foundation; either version 2 of; the License, or (at your option) any later version.;; The UCL library is distributed in the hope that it will be useful,; but WITHOUT ANY WARRANTY; without even the implied warranty of; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the; GNU General Public License for more details.;; You should have received a copy of the GNU General Public License; along with the UCL library; see the file COPYING.; If not, write to the Free Software Foundation, Inc.,; 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.;; Markus F.X.J. Oberhumer; <markus@oberhumer.com>; http://www.oberhumer.com/opensource/ucl/;; ------------- DECOMPRESSION -------------; Input; ds:si - source; es:di - dest; dx = ds; cx = 0; bx = 0x800F; bp = 1*/ CPU 8086section NRV2D16Sliteral_n2d: movsbdecompr_start_n2d: add bh, bh jnz dec1_n2d call reloadbh_n2ddec1_n2d: jc literal_n2d inc cx mov ax, essection N2D64K01 add di, di jnc di_ok_n2d add ah, 8 mov es, axdi_ok_n2d: shr di, 1section NRV2DEX1offset_loop_n2d: call getbit_cx_n2d jc offset_loopend_n2d dec cx call getbit_n2d adc cx, cx jns offset_loop_n2d jmps decomp_done_n2doffset_loopend_n2d: dec cx dec cx jzs offset_ok_n2dsection N2DX8601 add cx, cx add cx, cx add cx, cxsection N2D28601 CPU 286 shl cx, 3 CPU 8086section NRV2DEX2 mov bp, cx mov bl, [si] inc si not bl xor cx, cx shr bl, 1 jmps ook1_n2doffset_ok_n2d: call getbit_n2dook1_n2d: adc cx, cx call getbit_n2d adc cx, cx jnz copy_match_n2d inc cxlength_loop_n2d: call getbit_cx_n2d jnc length_loop_n2d inc cx inc cxcopy_match_n2d: cmp bp, 0x51 sbb cx, -2 sub ax, bp jbs handle_underflow_n2d mov ds, ax lea ax, [bx + di]ds_ok_n2d: sub ah, bh xchg ax, si rep movsb xchg ax, si mov ds, dx jmps decompr_start_n2dhandle_underflow_n2d:section N2DX8602 shl ax, 1 shl ax, 1 shl ax, 1 shl ax, 1 push ax xor ax, ax mov ds, ax pop axsection N2D28602 CPU 286 shl ax, 4 push 0 pop ds CPU 8086section NRV2DEX3 add ax, bx add ax, di jmps ds_ok_n2dgetbit_cx_n2d: add bh, bh jnz gb2_n2d call reloadbh_n2dgb2_n2d: adc cx, cxgetbit_n2d: add bh, bh jnzs f2_n2dreloadbh_n2d: mov bh, [si]section N2D64K02 adc si, si jnc si_ok_n2d add dh, 8 mov ds, dxsi_ok_n2d: shr si, 1section NRV2DEX9 inc si adc bh, bhf2_n2d: retdecomp_done_n2d:/* vim:set ts=4 et: */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -