mirror of
https://git.proxmox.com/git/qemu
synced 2025-08-07 12:58:20 +00:00
For consistency, move muls64 / mulu64 prototypes to host-utils.h
Make x86_64 optimized versions inline. git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3523 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
077fc2061e
commit
7a51ad822f
@ -91,9 +91,6 @@ void optimize_flags_init(void);
|
|||||||
extern FILE *logfile;
|
extern FILE *logfile;
|
||||||
extern int loglevel;
|
extern int loglevel;
|
||||||
|
|
||||||
void muls64(int64_t *phigh, int64_t *plow, int64_t a, int64_t b);
|
|
||||||
void mulu64(uint64_t *phigh, uint64_t *plow, uint64_t a, uint64_t b);
|
|
||||||
|
|
||||||
int gen_intermediate_code(CPUState *env, struct TranslationBlock *tb);
|
int gen_intermediate_code(CPUState *env, struct TranslationBlock *tb);
|
||||||
int gen_intermediate_code_pc(CPUState *env, struct TranslationBlock *tb);
|
int gen_intermediate_code_pc(CPUState *env, struct TranslationBlock *tb);
|
||||||
void dump_ops(const uint16_t *opc_buf, const uint32_t *opparam_buf);
|
void dump_ops(const uint16_t *opc_buf, const uint32_t *opparam_buf);
|
||||||
|
15
host-utils.c
15
host-utils.c
@ -28,6 +28,7 @@
|
|||||||
//#define DEBUG_MULDIV
|
//#define DEBUG_MULDIV
|
||||||
|
|
||||||
/* Long integer helpers */
|
/* Long integer helpers */
|
||||||
|
#if !defined(__x86_64__)
|
||||||
static void add128 (uint64_t *plow, uint64_t *phigh, uint64_t a, uint64_t b)
|
static void add128 (uint64_t *plow, uint64_t *phigh, uint64_t a, uint64_t b)
|
||||||
{
|
{
|
||||||
*plow += a;
|
*plow += a;
|
||||||
@ -69,17 +70,10 @@ static void mul64 (uint64_t *plow, uint64_t *phigh, uint64_t a, uint64_t b)
|
|||||||
*phigh += v;
|
*phigh += v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Unsigned 64x64 -> 128 multiplication */
|
/* Unsigned 64x64 -> 128 multiplication */
|
||||||
void mulu64 (uint64_t *plow, uint64_t *phigh, uint64_t a, uint64_t b)
|
void mulu64 (uint64_t *plow, uint64_t *phigh, uint64_t a, uint64_t b)
|
||||||
{
|
{
|
||||||
#if defined(__x86_64__)
|
|
||||||
__asm__ ("mul %0\n\t"
|
|
||||||
: "=d" (*phigh), "=a" (*plow)
|
|
||||||
: "a" (a), "0" (b));
|
|
||||||
#else
|
|
||||||
mul64(plow, phigh, a, b);
|
mul64(plow, phigh, a, b);
|
||||||
#endif
|
|
||||||
#if defined(DEBUG_MULDIV)
|
#if defined(DEBUG_MULDIV)
|
||||||
printf("mulu64: 0x%016llx * 0x%016llx = 0x%016llx%016llx\n",
|
printf("mulu64: 0x%016llx * 0x%016llx = 0x%016llx%016llx\n",
|
||||||
a, b, *phigh, *plow);
|
a, b, *phigh, *plow);
|
||||||
@ -89,11 +83,6 @@ void mulu64 (uint64_t *plow, uint64_t *phigh, uint64_t a, uint64_t b)
|
|||||||
/* Signed 64x64 -> 128 multiplication */
|
/* Signed 64x64 -> 128 multiplication */
|
||||||
void muls64 (uint64_t *plow, uint64_t *phigh, int64_t a, int64_t b)
|
void muls64 (uint64_t *plow, uint64_t *phigh, int64_t a, int64_t b)
|
||||||
{
|
{
|
||||||
#if defined(__x86_64__)
|
|
||||||
__asm__ ("imul %0\n\t"
|
|
||||||
: "=d" (*phigh), "=a" (*plow)
|
|
||||||
: "a" (a), "0" (b));
|
|
||||||
#else
|
|
||||||
int sa, sb;
|
int sa, sb;
|
||||||
|
|
||||||
sa = (a < 0);
|
sa = (a < 0);
|
||||||
@ -106,9 +95,9 @@ void muls64 (uint64_t *plow, uint64_t *phigh, int64_t a, int64_t b)
|
|||||||
if (sa ^ sb) {
|
if (sa ^ sb) {
|
||||||
neg128(plow, phigh);
|
neg128(plow, phigh);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
#if defined(DEBUG_MULDIV)
|
#if defined(DEBUG_MULDIV)
|
||||||
printf("muls64: 0x%016llx * 0x%016llx = 0x%016llx%016llx\n",
|
printf("muls64: 0x%016llx * 0x%016llx = 0x%016llx%016llx\n",
|
||||||
a, b, *phigh, *plow);
|
a, b, *phigh, *plow);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
#endif /* !defined(__x86_64__) */
|
||||||
|
53
host-utils.h
53
host-utils.h
@ -23,6 +23,28 @@
|
|||||||
* THE SOFTWARE.
|
* THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if defined(__x86_64__)
|
||||||
|
#define __HAVE_FAST_MULU64__
|
||||||
|
static always_inline void mulu64 (uint64_t *plow, uint64_t *phigh,
|
||||||
|
uint64_t a, uint64_t b)
|
||||||
|
{
|
||||||
|
__asm__ ("mul %0\n\t"
|
||||||
|
: "=d" (*phigh), "=a" (*plow)
|
||||||
|
: "a" (a), "0" (b));
|
||||||
|
}
|
||||||
|
#define __HAVE_FAST_MULS64__
|
||||||
|
static always_inline void muls64 (uint64_t *plow, uint64_t *phigh,
|
||||||
|
int64_t a, int64_t b)
|
||||||
|
{
|
||||||
|
__asm__ ("imul %0\n\t"
|
||||||
|
: "=d" (*phigh), "=a" (*plow)
|
||||||
|
: "a" (a), "0" (b));
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
void muls64(int64_t *phigh, int64_t *plow, int64_t a, int64_t b);
|
||||||
|
void mulu64(uint64_t *phigh, uint64_t *plow, uint64_t a, uint64_t b);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Note that some of those functions may end up calling libgcc functions,
|
/* Note that some of those functions may end up calling libgcc functions,
|
||||||
depending on the host machine. It is up to the target emulation to
|
depending on the host machine. It is up to the target emulation to
|
||||||
cope with that. */
|
cope with that. */
|
||||||
@ -68,34 +90,13 @@ static always_inline int clz64(uint64_t val)
|
|||||||
{
|
{
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
|
|
||||||
if (!(val & 0xFFFFFFFF00000000ULL)) {
|
if (!(val >> 32)) {
|
||||||
cnt += 32;
|
cnt += 32;
|
||||||
val <<= 32;
|
} else {
|
||||||
|
val >>= 32;
|
||||||
}
|
}
|
||||||
if (!(val & 0xFFFF000000000000ULL)) {
|
|
||||||
cnt += 16;
|
return cnt + clz32(val);
|
||||||
val <<= 16;
|
|
||||||
}
|
|
||||||
if (!(val & 0xFF00000000000000ULL)) {
|
|
||||||
cnt += 8;
|
|
||||||
val <<= 8;
|
|
||||||
}
|
|
||||||
if (!(val & 0xF000000000000000ULL)) {
|
|
||||||
cnt += 4;
|
|
||||||
val <<= 4;
|
|
||||||
}
|
|
||||||
if (!(val & 0xC000000000000000ULL)) {
|
|
||||||
cnt += 2;
|
|
||||||
val <<= 2;
|
|
||||||
}
|
|
||||||
if (!(val & 0x8000000000000000ULL)) {
|
|
||||||
cnt++;
|
|
||||||
val <<= 1;
|
|
||||||
}
|
|
||||||
if (!(val & 0x8000000000000000ULL)) {
|
|
||||||
cnt++;
|
|
||||||
}
|
|
||||||
return cnt;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static always_inline int clo64(uint64_t val)
|
static always_inline int clo64(uint64_t val)
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "exec.h"
|
#include "exec.h"
|
||||||
|
#include "host-utils.h"
|
||||||
|
|
||||||
#include "op_helper.h"
|
#include "op_helper.h"
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
#include "exec.h"
|
#include "exec.h"
|
||||||
|
#include "host-utils.h"
|
||||||
|
|
||||||
//#define DEBUG_PCALL
|
//#define DEBUG_PCALL
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user