added relevant parts of libgcc
[mdlife] / src / libc / gcc.S
diff --git a/src/libc/gcc.S b/src/libc/gcc.S
new file mode 100644 (file)
index 0000000..add726d
--- /dev/null
@@ -0,0 +1,45 @@
+/* libgcc routines for 68000 w/o floating-point hardware.
+   Copyright (C) 1994-2019 Free Software Foundation, Inc.
+
+This file is part of GCC.
+
+GCC 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 3, or (at your option) any
+later version.
+
+This file 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.
+
+Under Section 7 of GPL version 3, you are granted additional
+permissions described in the GCC Runtime Library Exception, version
+3.1, as published by the Free Software Foundation.
+
+You should have received a copy of the GNU General Public License and
+a copy of the GCC Runtime Library Exception along with this program;
+see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
+<http://www.gnu.org/licenses/>.  */
+
+/* Use this one for any 680x0; assumes no floating point hardware.
+   The trailing " '" appearing on some lines is for ANSI preprocessors.  Yuk.
+   Some of this code comes from MINIX, via the folks at ericsson.
+   D. V. Henkel-Wallace (gumby@cygnus.com) Fete Bastille, 1992
+*/
+
+
+       .text
+       .globl  __mulsi3
+__mulsi3:
+       move.w  4(%sp), %d0     /* x0 -> d0 */
+       mulu.w  10(%sp), %d0    /* x0*y1 */
+       move.w  6(%sp), %d1     /* x1 -> d1 */
+       mulu.w  8(%sp), %d1     /* x1*y0 */
+       add.w   %d1, %d0
+       swap    %d0
+       clr.w   %d0
+       move.w  6(%sp), %d1     /* x1 -> d1 */
+       mulu.w  10(%sp), %d1    /* x1*y1 */
+       add.l   %d1, %d0
+       rts