1 ;
-------------------------------------------------------------------------
2 ; _muluchar.s
- routine for multiplication of
8 bit
(unsigned char
)
4 ; Copyright
(C
) 2009, Ullrich von Bassewitz
5 ; Copyright
(C
) 2022-2023, Gabriele Gorla
7 ; This library is free software; you can redistribute it
and/or modify it
8 ; under the terms of the GNU General Public License as published by the
9 ; Free Software Foundation; either version
2, or (at your option
) any
12 ; This library is distributed in the hope that it will
be useful
,
13 ; but WITHOUT ANY WARRANTY; without even the implied warranty of
14 ; MERCHANTABILITY
or FITNESS FOR
A PARTICULAR PURPOSE. See the
15 ; GNU General Public License for more details.
17 ; You should have received
a copy of the GNU General Public License
18 ; along with this library; see the file COPYING. If
not, write to the
19 ; Free Software Foundation
, 51 Franklin Street
, Fifth Floor
, Boston
,
22 ; As
a special exception
, if you link this library with other files
,
23 ; some of which are compiled with SDCC
, to produce an executable
,
24 ; this library does
not by itself cause the resulting executable to
25 ;
be covered by the GNU General Public License. This exception does
26 ;
not however invalidate any other reasons why the executable file
27 ; might
be covered by the GNU General Public License.
28 ;
-------------------------------------------------------------------------
32 ;
--------------------------------------------------------
34 ;
--------------------------------------------------------
35 .globl __muluchar ; arguments in A and X, result in AX
36 .globl ___umul8 ; arguments in ret0 and ret1, result in AX
38 ;
--------------------------------------------------------
39 ; overlayable function parameters in zero page
40 ;
--------------------------------------------------------
43 ;
--------------------------------------------------------
45 ;
--------------------------------------------------------
46 .define arg1 "___SDCC_m6502_ret0"
47 .define arg2 "___SDCC_m6502_ret2"
49 ;
--------------------------------------------------------
51 ;
--------------------------------------------------------
59 ldy
#8 ; Number of bits
60 lsr
*arg2 ; Get first bit of RHS into carry
68 tax ; Load the result MSB
69 lda
*arg2 ; Load the result LSB