Testing latest pari + WASM + node.js... and it works?! Wow.
License: GPL3
ubuntu2004
#line 2 "../src/kernel/aarch64/asm0.h"1/* Copyright (C) 2015 The PARI group.23This file is part of the PARI/GP package.45PARI/GP is free software; you can redistribute it and/or modify it under the6terms of the GNU General Public License as published by the Free Software7Foundation; either version 2 of the License, or (at your option) any later8version. It is distributed in the hope that it will be useful, but WITHOUT9ANY WARRANTY WHATSOEVER.1011Check the License for details. You should have received a copy of it, along12with the package; see the file 'COPYING'. If not, write to the Free Software13Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */1415/*16ASM addll mulll bfffo17NOASM divll18*/1920#ifdef ASMINLINE21#define LOCAL_HIREMAINDER register ulong hiremainder22#define LOCAL_OVERFLOW register ulong overflow2324#define addll(a, b) \25__extension__ ({ ulong __value, __arg1 = (a), __arg2 = (b); \26__asm__ ("adds %0,%2,%3\n\tadc %1,xzr,xzr\n\t" \27: "=&r" (__value), "=&r" (overflow) \28: "r" (__arg1), "r" (__arg2): "cc"); \29__value; \30})3132#define addllx(a, b) \33__extension__ ({ ulong __value, __arg1 = (a), __arg2 = (b); \34__asm__ ("subs xzr,%4,#1\n\tadcs %0,%2,%3\n\tadc %1,xzr,xzr\n\t" \35: "=&r" (__value), "=&r" (overflow) \36: "r" (__arg1), "r" (__arg2), "r" (overflow): "cc"); \37__value; \38})3940#define addllx8(a,b,c,overflow) \41do { long *__arg1 = a, *__arg2 = b, *__out = c; \42ulong __temp1, __temp2; \43__asm__( \44"subs xzr,%6,#1\n\t" \45" ldr %0, [%3] \n\t ldr %1, [%4] \n\t adcs %1, %0, %1\n\t str %1, [%5] \n\t" \46" ldr %0, [%3,-8] \n\t ldr %1, [%4,-8] \n\t adcs %1, %0, %1\n\t str %1, [%5,-8] \n\t" \47" ldr %0, [%3,-16] \n\t ldr %1, [%4,-16]\n\t adcs %1, %0, %1\n\t str %1, [%5,-16]\n\t" \48" ldr %0, [%3,-24] \n\t ldr %1, [%4,-24]\n\t adcs %1, %0, %1\n\t str %1, [%5,-24]\n\t" \49" ldr %0, [%3,-32] \n\t ldr %1, [%4,-32]\n\t adcs %1, %0, %1\n\t str %1, [%5,-32]\n\t" \50" ldr %0, [%3,-40] \n\t ldr %1, [%4,-40]\n\t adcs %1, %0, %1\n\t str %1, [%5,-40]\n\t" \51" ldr %0, [%3,-48] \n\t ldr %1, [%4,-48]\n\t adcs %1, %0, %1\n\t str %1, [%5,-48]\n\t" \52" ldr %0, [%3,-56] \n\t ldr %1, [%4,-56]\n\t adcs %1, %0, %1\n\t str %1, [%5,-56]\n\t" \53"adc %2,xzr,xzr\n\t" \54: "=&r" (__temp1), "=&r" (__temp2), "=&r" (overflow) \55: "r" (__arg1), "r" (__arg2), "r" (__out), "r" (overflow), \56"0" ((ulong)0), "1" ((ulong)0) \57: "cc"); \58} while(0)5960#define subll(a, b) \61__extension__ ({ ulong __value, __arg1 = (a), __arg2 = (b); \62__asm__ ("subs %0,%2,%3\n\tngc %1,xzr\n\tsub %1,xzr,%1\n\t" \63: "=&r" (__value), "=&r" (overflow) \64: "r" (__arg1), "r" (__arg2): "cc"); \65__value; \66})6768#define subllx(a, b) \69__extension__ ({ ulong __value, __arg1 = (a), __arg2 = (b); \70__asm__ ("subs xzr,xzr,%4\n\tsbcs %0,%2,%3\n\tngc %1,xzr\n\tsub %1,xzr,%1\n\t" \71: "=&r" (__value), "=&r" (overflow) \72: "r" (__arg1), "r" (__arg2), "r" (overflow): "cc"); \73__value; \74})7576#define subllx8(a,b,c,overflow) \77do { long *__arg1 = a, *__arg2 = b, *__out = c; \78ulong __temp1, __temp2; \79__asm__( \80"subs xzr,xzr,%6\n\t" \81" ldr %0, [%3] \n\t ldr %1, [%4] \n\t sbcs %1, %0, %1\n\t str %1, [%5] \n\t" \82" ldr %0, [%3,-8] \n\t ldr %1, [%4,-8] \n\t sbcs %1, %0, %1\n\t str %1, [%5,-8] \n\t" \83" ldr %0, [%3,-16] \n\t ldr %1, [%4,-16]\n\t sbcs %1, %0, %1\n\t str %1, [%5,-16]\n\t" \84" ldr %0, [%3,-24] \n\t ldr %1, [%4,-24]\n\t sbcs %1, %0, %1\n\t str %1, [%5,-24]\n\t" \85" ldr %0, [%3,-32] \n\t ldr %1, [%4,-32]\n\t sbcs %1, %0, %1\n\t str %1, [%5,-32]\n\t" \86" ldr %0, [%3,-40] \n\t ldr %1, [%4,-40]\n\t sbcs %1, %0, %1\n\t str %1, [%5,-40]\n\t" \87" ldr %0, [%3,-48] \n\t ldr %1, [%4,-48]\n\t sbcs %1, %0, %1\n\t str %1, [%5,-48]\n\t" \88" ldr %0, [%3,-56] \n\t ldr %1, [%4,-56]\n\t sbcs %1, %0, %1\n\t str %1, [%5,-56]\n\t" \89"ngc %2,xzr\n\tsub %2,xzr,%2\n\t" \90: "=&r" (__temp1), "=&r" (__temp2), "=&r" (overflow) \91: "r" (__arg1), "r" (__arg2), "r" (__out), "r" (overflow), \92"0" ((ulong)0), "1" ((ulong)0) \93: "cc"); \94} while(0)9596#define mulll(a, b) \97__extension__ ({ ulong __value, __arg1 = (a), __arg2 = (b); \98__asm__ ("mul %0,%1,%2\n\t" \99: "=r" (__value) : "r" (__arg1), "r" (__arg2)); \100__asm__ ("umulh %0,%1,%2\n\t" \101: "=r" (hiremainder) : "r" (__arg1), "r" (__arg2)); \102__value; \103})104105#define addmul(a, b) \106__extension__ ({ ulong __value, __arg1 = (a), __arg2 = (b), __hi; \107__asm__ ("madd %0,%1,%2,%3\n\t" \108: "=r" (__value) : "r" (__arg1), "r" (__arg2), "r" (hiremainder)); \109__asm__ ("umulh %0,%1,%2\n\t" \110: "=r" (__hi) : "r" (__arg1), "r" (__arg2)); \111hiremainder = (__value < hiremainder) ? __hi+1: __hi;\112__value; \113})114115#define bfffo(a) \116__extension__ ({ ulong __a = (a), __value; \117__asm__ ("clz %0, %1" : "=r" (__value) : "r" (__a)); \118__value; \119})120121#endif122123124