⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 m_00000000001204375370_1388225734.c

📁 32位单精度浮点加法器
💻 C
字号:
/**********************************************************************/
/*   ____  ____                                                       */
/*  /   /\/   /                                                       */
/* /___/  \  /                                                        */
/* \   \   \/                                                       */
/*  \   \        Copyright (c) 2003-2009 Xilinx, Inc.                */
/*  /   /          All Right Reserved.                                 */
/* /---/   /\                                                         */
/* \   \  /  \                                                      */
/*  \___\/\___\                                                    */
/***********************************************************************/

/* This file is designed for use with ISim build 0xa0883be4 */

#define XSI_HIDE_SYMBOL_SPEC true
#include "xsi.h"
#include <memory.h>
#ifdef __GNUC__
#include <stdlib.h>
#else
#include <malloc.h>
#define alloca _alloca
#endif
static const char *ng0 = "E:/kechengsheji/ha1/wave_gen_ver_s6/tb_uart_driver.v";
static const char *ng1 = "%t       Sending character %x (%c)";
static unsigned int ng2[] = {0U, 0U};
static int ng3[] = {0, 0};
static int ng4[] = {7, 0};
static int ng5[] = {1, 0};
static unsigned int ng6[] = {1U, 0U};



static int sp_set_bitper(char *t1, char *t2)
{
    int t0;
    char *t3;
    char *t4;
    char *t5;
    char *t6;
    char *t7;
    char *t8;

LAB0:    t0 = 1;
    t3 = (t2 + 48U);
    t4 = *((char **)t3);
    if (t4 == 0)
        goto LAB2;

LAB3:    goto *t4;

LAB2:    t4 = (t1 + 984);
    xsi_vlog_subprogram_setdisablestate(t4, &&LAB4);
    xsi_set_current_line(73, ng0);

LAB5:    xsi_set_current_line(74, ng0);
    t5 = (t1 + 3632);
    t6 = (t5 + 56U);
    t7 = *((char **)t6);
    t8 = (t1 + 3312);
    xsi_vlogvar_assign_value(t8, t7, 0, 0, 64);

LAB4:    xsi_vlog_dispose_subprogram_invocation(t2);
    t4 = (t2 + 48U);
    *((char **)t4) = &&LAB2;
    t0 = 0;

LAB1:    return t0;
}

static int sp_send_char_bitper(char *t1, char *t2)
{
    char t6[8];
    char t20[8];
    int t0;
    char *t3;
    char *t4;
    double t5;
    char *t7;
    char *t8;
    char *t9;
    char *t10;
    char *t11;
    char *t12;
    char *t13;
    double t14;
    unsigned int t15;
    unsigned int t16;
    unsigned int t17;
    unsigned int t18;
    unsigned int t19;
    char *t21;
    char *t22;
    char *t23;
    char *t24;
    char *t25;
    char *t26;
    char *t27;

LAB0:    t0 = 1;
    t3 = (t2 + 48U);
    t4 = *((char **)t3);
    if (t4 == 0)
        goto LAB2;

LAB3:    goto *t4;

LAB2:    t4 = (t1 + 1416);
    xsi_vlog_subprogram_setdisablestate(t4, &&LAB4);
    xsi_set_current_line(84, ng0);

LAB5:    xsi_set_current_line(85, ng0);
    t5 = xsi_vlog_realtime(1000.0000000000000, 1000.0000000000000);
    *((double *)t6) = t5;
    t7 = (t1 + 3792);
    t8 = (t7 + 56U);
    t9 = *((char **)t8);
    t10 = (t1 + 3792);
    t11 = (t10 + 56U);
    t12 = *((char **)t11);
    t13 = (t1 + 1416);
    xsi_vlogfile_write(1, 0, 0, ng1, 4, t13, (char)114, t6, 64, (char)118, t9, 8, (char)118, t12, 8);
    xsi_set_current_line(86, ng0);
    t4 = ((char*)((ng2)));
    t7 = (t1 + 3472);
    xsi_vlogvar_assign_value(t7, t4, 0, 0, 1);
    xsi_set_current_line(87, ng0);
    t4 = (t1 + 3952);
    t7 = (t4 + 56U);
    t8 = *((char **)t7);
    t5 = xsi_vlog_convert_to_real(t8, 64, 2);
    t5 = (t5 * 1000.0000000000000);
    t14 = (t5 < 0.00000000000000000);
    if (t14 == 1)
        goto LAB6;

LAB7:    t5 = (t5 + 0.50000000000000000);
    t5 = ((int64)(t5));

LAB8:    t5 = (t5 * 1.0000000000000000);
    t9 = (t2 + 56U);
    t10 = *((char **)t9);
    xsi_process_wait(t10, t5);
    *((char **)t3) = &&LAB9;
    t0 = 1;

LAB1:    return t0;
LAB4:    xsi_vlog_dispose_subprogram_invocation(t2);
    t4 = (t2 + 48U);
    *((char **)t4) = &&LAB2;
    t0 = 0;
    goto LAB1;

LAB6:    t5 = 0.00000000000000000;
    goto LAB8;

LAB9:    xsi_set_current_line(88, ng0);
    xsi_set_current_line(88, ng0);
    t4 = ((char*)((ng3)));
    t7 = (t1 + 4112);
    xsi_vlogvar_assign_value(t7, t4, 0, 0, 32);

LAB10:    t4 = (t1 + 4112);
    t7 = (t4 + 56U);
    t8 = *((char **)t7);
    t9 = ((char*)((ng4)));
    memset(t6, 0, 8);
    xsi_vlog_signed_leq(t6, 32, t8, 32, t9, 32);
    t10 = (t6 + 4);
    t15 = *((unsigned int *)t10);
    t16 = (~(t15));
    t17 = *((unsigned int *)t6);
    t18 = (t17 & t16);
    t19 = (t18 != 0);
    if (t19 > 0)
        goto LAB11;

LAB12:    xsi_set_current_line(93, ng0);
    t4 = ((char*)((ng6)));
    t7 = (t1 + 3472);
    xsi_vlogvar_assign_value(t7, t4, 0, 0, 1);
    xsi_set_current_line(94, ng0);
    t4 = (t1 + 3952);
    t7 = (t4 + 56U);
    t8 = *((char **)t7);
    t5 = xsi_vlog_convert_to_real(t8, 64, 2);
    t5 = (t5 * 1000.0000000000000);
    t14 = (t5 < 0.00000000000000000);
    if (t14 == 1)
        goto LAB18;

LAB19:    t5 = (t5 + 0.50000000000000000);
    t5 = ((int64)(t5));

LAB20:    t5 = (t5 * 1.0000000000000000);
    t9 = (t2 + 56U);
    t10 = *((char **)t9);
    xsi_process_wait(t10, t5);
    *((char **)t3) = &&LAB21;
    t0 = 1;
    goto LAB1;

LAB11:    xsi_set_current_line(89, ng0);

LAB13:    xsi_set_current_line(90, ng0);
    t11 = (t1 + 3792);
    t12 = (t11 + 56U);
    t13 = *((char **)t12);
    t21 = (t1 + 3792);
    t22 = (t21 + 72U);
    t23 = *((char **)t22);
    t24 = (t1 + 4112);
    t25 = (t24 + 56U);
    t26 = *((char **)t25);
    xsi_vlog_generic_get_index_select_value(t20, 1, t13, t23, 2, t26, 32, 1);
    t27 = (t1 + 3472);
    xsi_vlogvar_assign_value(t27, t20, 0, 0, 1);
    xsi_set_current_line(91, ng0);
    t4 = (t1 + 3952);
    t7 = (t4 + 56U);
    t8 = *((char **)t7);
    t5 = xsi_vlog_convert_to_real(t8, 64, 2);
    t5 = (t5 * 1000.0000000000000);
    t14 = (t5 < 0.00000000000000000);
    if (t14 == 1)
        goto LAB14;

LAB15:    t5 = (t5 + 0.50000000000000000);
    t5 = ((int64)(t5));

LAB16:    t5 = (t5 * 1.0000000000000000);
    t9 = (t2 + 56U);
    t10 = *((char **)t9);
    xsi_process_wait(t10, t5);
    *((char **)t3) = &&LAB17;
    t0 = 1;
    goto LAB1;

LAB14:    t5 = 0.00000000000000000;
    goto LAB16;

LAB17:    xsi_set_current_line(88, ng0);
    t4 = (t1 + 4112);
    t7 = (t4 + 56U);
    t8 = *((char **)t7);
    t9 = ((char*)((ng5)));
    memset(t6, 0, 8);
    xsi_vlog_signed_add(t6, 32, t8, 32, t9, 32);
    t10 = (t1 + 4112);
    xsi_vlogvar_assign_value(t10, t6, 0, 0, 32);
    goto LAB10;

LAB18:    t5 = 0.00000000000000000;
    goto LAB20;

LAB21:    goto LAB4;

}

static int sp_send_char(char *t1, char *t2)
{
    int t0;
    char *t3;
    char *t4;
    char *t5;
    char *t6;
    char *t7;
    char *t8;
    char *t9;
    char *t10;
    char *t11;
    char *t12;
    char *t13;
    char *t14;
    char *t15;
    char *t16;
    char *t17;
    char *t18;
    char *t19;
    char *t20;
    char *t21;
    char *t22;
    char *t23;
    char *t24;
    char *t25;
    char *t26;
    char *t27;
    char *t28;
    int t29;
    char *t30;
    char *t31;
    char *t32;
    char *t33;

LAB0:    t0 = 1;
    t3 = (t2 + 48U);
    t4 = *((char **)t3);
    if (t4 == 0)
        goto LAB2;

LAB3:    goto *t4;

LAB2:    t4 = (t1 + 1848);
    xsi_vlog_subprogram_setdisablestate(t4, &&LAB4);
    xsi_set_current_line(101, ng0);

LAB5:    xsi_set_current_line(102, ng0);
    t5 = (t1 + 4272);
    t6 = (t5 + 56U);
    t7 = *((char **)t6);
    t8 = (t1 + 3312);
    t9 = (t8 + 56U);
    t10 = *((char **)t9);
    t11 = (t2 + 56U);
    t12 = *((char **)t11);
    t13 = (t2 + 56U);
    t14 = *((char **)t13);
    xsi_vlog_subprograminvocation_setJumpstate(t2, t14, &&LAB6);
    t15 = (t2 + 56U);
    t16 = *((char **)t15);
    t17 = (t1 + 1416);
    t18 = xsi_create_subprogram_invocation(t16, 0, t1, t17, 0, t2);
    xsi_vlog_subprogram_pushinvocation(t17, t18);
    t19 = (t1 + 3792);
    xsi_vlogvar_assign_value(t19, t7, 0, 0, 8);
    t20 = (t1 + 3952);
    xsi_vlogvar_assign_value(t20, t10, 0, 0, 64);

LAB8:    t21 = (t2 + 64U);
    t22 = *((char **)t21);
    t23 = (t22 + 80U);
    t24 = *((char **)t23);
    t25 = (t24 + 272U);
    t26 = *((char **)t25);
    t27 = (t26 + 0U);
    t28 = *((char **)t27);
    t29 = ((int  (*)(char *, char *))t28)(t1, t22);
    if (t29 == -1)
        goto LAB9;

LAB10:    if (t29 != 0)
        goto LAB11;

LAB6:    t22 = (t1 + 1416);
    xsi_vlog_subprogram_popinvocation(t22);

LAB7:    t30 = (t2 + 64U);
    t31 = *((char **)t30);
    t30 = (t1 + 1416);
    t32 = (t2 + 56U);
    t33 = *((char **)t32);
    xsi_delete_subprogram_invocation(t30, t31, t1, t33, t2);

LAB4:    xsi_vlog_dispose_subprogram_invocation(t2);
    t4 = (t2 + 48U);
    *((char **)t4) = &&LAB2;
    t0 = 0;

LAB1:    return t0;
LAB9:    t0 = -1;
    goto LAB1;

LAB11:    t21 = (t2 + 48U);
    *((char **)t21) = &&LAB8;
    goto LAB1;

}

static int sp_send_char_push(char *t1, char *t2)
{
    int t0;
    char *t3;
    char *t4;
    char *t5;
    char *t6;
    char *t7;
    char *t8;
    char *t9;
    char *t10;
    char *t11;
    char *t12;
    char *t13;
    char *t14;
    char *t15;
    char *t16;
    char *t17;
    char *t18;
    char *t19;
    char *t20;
    char *t21;
    char *t22;
    char *t23;
    char *t24;
    char *t25;
    char *t26;
    char *t27;
    char *t28;
    int t29;
    char *t30;
    char *t31;
    char *t32;
    char *t33;
    char *t34;
    char *t35;

LAB0:    t0 = 1;
    t3 = (t2 + 48U);
    t4 = *((char **)t3);
    if (t4 == 0)
        goto LAB2;

LAB3:    goto *t4;

LAB2:    t4 = (t1 + 2280);
    xsi_vlog_subprogram_setdisablestate(t4, &&LAB4);
    xsi_set_current_line(109, ng0);

LAB5:    xsi_set_current_line(110, ng0);
    t5 = (t1 + 4432);
    t6 = (t5 + 56U);
    t7 = *((char **)t6);
    t8 = (t2 + 56U);
    t9 = *((char **)t8);
    t10 = (t2 + 56U);
    t11 = *((char **)t10);
    xsi_vlog_subprograminvocation_setJumpstate(t2, t11, &&LAB6);
    t12 = (t2 + 56U);
    t13 = *((char **)t12);
    t14 = (t1 + 7600);
    t15 = *((char **)t14);
    t16 = (t1 + 7616);
    t17 = xsi_create_subprogram_invocation(t13, 0, *((char **)t16), ((char*)(t15)), 0, t2);
    xsi_vlog_subprogram_pushinvocation(((char*)(t15)), t17);
    t18 = (t1 + 7608);
    t19 = *((char **)t18);
    xsi_vlogvar_assign_value(((char*)(t19)), t7, 0, 0, 8);

LAB8:    t20 = (t2 + 64U);
    t21 = *((char **)t20);
    t22 = (t21 + 80U);
    t23 = *((char **)t22);
    t24 = (t23 + 272U);
    t25 = *((char **)t24);
    t26 = (t25 + 0U);
    t27 = *((char **)t26);
    t28 = (t1 + 7616);
    t29 = ((int  (*)(char *, char *))t27)(*((char **)t28), t21);
    if (t29 == -1)
        goto LAB9;

LAB10:    if (t29 != 0)
        goto LAB11;

LAB6:    t21 = (t1 + 7648);
    t30 = *((char **)t21);
    xsi_vlog_subprogram_popinvocation(((char*)(t30)));

LAB7:    t31 = (t2 + 64U);
    t32 = *((char **)t31);
    t31 = (t1 + 7648);
    t33 = *((char **)t31);
    t34 = (t2 + 56U);
    t35 = *((char **)t34);
    xsi_delete_subprogram_invocation(((char*)(t33)), t32, t1, t35, t2);
    xsi_set_current_line(111, ng0);
    t4 = (t1 + 4432);
    t5 = (t4 + 56U);
    t6 = *((char **)t5);
    t7 = (t2 + 56U);
    t8 = *((char **)t7);
    t9 = (t2 + 56U);
    t10 = *((char **)t9);
    xsi_vlog_subprograminvocation_setJumpstate(t2, t10, &&LAB12);
    t11 = (t2 + 56U);
    t12 = *((char **)t11);
    t13 = (t1 + 1848);
    t14 = xsi_create_subprogram_invocation(t12, 0, t1, t13, 0, t2);
    xsi_vlog_subprogram_pushinvocation(t13, t14);
    t15 = (t1 + 4272);
    xsi_vlogvar_assign_value(t15, t6, 0, 0, 8);

LAB14:    t16 = (t2 + 64U);
    t17 = *((char **)t16);
    t18 = (t17 + 80U);
    t19 = *((char **)t18);
    t20 = (t19 + 272U);
    t21 = *((char **)t20);
    t22 = (t21 + 0U);
    t23 = *((char **)t22);
    t29 = ((int  (*)(char *, char *))t23)(t1, t17);
    if (t29 == -1)
        goto LAB15;

LAB16:    if (t29 != 0)
        goto LAB17;

LAB12:    t17 = (t1 + 1848);
    xsi_vlog_subprogram_popinvocation(t17);

LAB13:    t24 = (t2 + 64U);
    t25 = *((char **)t24);
    t24 = (t1 + 1848);
    t26 = (t2 + 56U);
    t27 = *((char **)t26);
    xsi_delete_subprogram_invocation(t24, t25, t1, t27, t2);

LAB4:    xsi_vlog_dispose_subprogram_invocation(t2);
    t4 = (t2 + 48U);
    *((char **)t4) = &&LAB2;
    t0 = 0;

LAB1:    return t0;
LAB9:    t0 = -1;
    goto LAB1;

LAB11:    t20 = (t2 + 48U);
    *((char **)t20) = &&LAB8;
    goto LAB1;

LAB15:    t0 = -1;
    goto LAB1;

LAB17:    t16 = (t2 + 48U);
    *((char **)t16) = &&LAB14;
    goto LAB1;

}

static void Cont_119_0(char *t0)
{
    char *t1;
    char *t2;
    char *t3;
    char *t4;
    char *t5;
    char *t6;
    char *t7;
    char *t8;
    char *t9;
    unsigned int t10;
    unsigned int t11;
    char *t12;
    unsigned int t13;
    unsigned int t14;
    char *t15;
    unsigned int t16;
    unsigned int t17;
    char *t18;

LAB0:    t1 = (t0 + 5352U);
    t2 = *((char **)t1);
    if (t2 == 0)
        goto LAB2;

LAB3:    goto *t2;

LAB2:    xsi_set_current_line(119, ng0);
    t2 = (t0 + 3472);
    t3 = (t2 + 56U);
    t4 = *((char **)t3);
    t5 = (t0 + 5752);
    t6 = (t5 + 56U);
    t7 = *((char **)t6);
    t8 = (t7 + 56U);
    t9 = *((char **)t8);
    memset(t9, 0, 8);
    t10 = 1U;
    t11 = t10;
    t12 = (t4 + 4);
    t13 = *((unsigned int *)t4);
    t10 = (t10 & t13);
    t14 = *((unsigned int *)t12);
    t11 = (t11 & t14);
    t15 = (t9 + 4);
    t16 = *((unsigned int *)t9);
    *((unsigned int *)t9) = (t16 | t10);
    t17 = *((unsigned int *)t15);
    *((unsigned int *)t15) = (t17 | t11);
    xsi_driver_vfirst_trans(t5, 0, 0);
    t18 = (t0 + 5672);
    *((int *)t18) = 1;

LAB1:    return;
}


extern void work_m_00000000001204375370_1388225734_init()
{
	static char *pe[] = {(void *)Cont_119_0};
	static char *se[] = {(void *)sp_set_bitper,(void *)sp_send_char_bitper,(void *)sp_send_char,(void *)sp_send_char_push};
	xsi_register_didat("work_m_00000000001204375370_1388225734", "isim/test_wave_gen_isim_beh.exe.sim/work/m_00000000001204375370_1388225734.didat");
	xsi_register_executes(pe);
	xsi_register_subprogram_executes(se);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -