URL
https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk
Go to most recent revision |
Only display areas with differences |
Details |
Blame |
View Log
Rev 149 |
Rev 154 |
/* Source: PR 321 modified for test suite by Neil Booth 14 Jan 2001. */
|
/* Source: PR 321 modified for test suite by Neil Booth 14 Jan 2001. */
|
|
|
typedef unsigned long long uint64;
|
typedef unsigned long long uint64;
|
unsigned long pars;
|
unsigned long pars;
|
|
|
uint64 b[32];
|
uint64 b[32];
|
uint64 *r = b;
|
uint64 *r = b;
|
|
|
void alpha_ep_extbl_i_eq_0()
|
void alpha_ep_extbl_i_eq_0()
|
{
|
{
|
unsigned int rb, ra, rc;
|
unsigned int rb, ra, rc;
|
|
|
rb = (((unsigned long)(pars) >> 27)) & 0x1fUL;
|
rb = (((unsigned long)(pars) >> 27)) & 0x1fUL;
|
ra = (((unsigned int)(pars) >> 5)) & 0x1fUL;
|
ra = (((unsigned int)(pars) >> 5)) & 0x1fUL;
|
rc = (((unsigned int)(pars) >> 0)) & 0x1fUL;
|
rc = (((unsigned int)(pars) >> 0)) & 0x1fUL;
|
{
|
{
|
uint64 temp = ((r[ra] >> ((r[rb] & 0x7) << 3)) & 0x00000000000000FFLL);
|
uint64 temp = ((r[ra] >> ((r[rb] & 0x7) << 3)) & 0x00000000000000FFLL);
|
if (rc != 31)
|
if (rc != 31)
|
r[rc] = temp;
|
r[rc] = temp;
|
}
|
}
|
}
|
}
|
|
|
int
|
int
|
main(void)
|
main(void)
|
{
|
{
|
if (sizeof (uint64) == 8)
|
if (sizeof (uint64) == 8)
|
{
|
{
|
b[17] = 0x0000000000303882ULL; /* rb */
|
b[17] = 0x0000000000303882ULL; /* rb */
|
b[2] = 0x534f4f4c494d000aULL; /* ra & rc */
|
b[2] = 0x534f4f4c494d000aULL; /* ra & rc */
|
|
|
pars = 0x88000042; /* 17, 2, 2 coded */
|
pars = 0x88000042; /* 17, 2, 2 coded */
|
alpha_ep_extbl_i_eq_0();
|
alpha_ep_extbl_i_eq_0();
|
|
|
if (b[2] != 0x4d)
|
if (b[2] != 0x4d)
|
abort ();
|
abort ();
|
}
|
}
|
|
|
exit (0);
|
exit (0);
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.