主要内容

启动和终止行为在遗留功能

这个例子向您展示了如何使用遗留代码工具集成遗留的C函数开始和终止操作。

遗留代码工具允许您:

  • 提供遗留功能规范,

  • 生成一个C-MEX s函数在使用模拟调用遗留代码,和

  • 编译和构建模拟生成的功能。

提供遗留功能规范

遗留代码工具提供的功能需要一个特定的数据结构或数组的结构作为参数。数据结构是通过调用初始化函数legacy_code()使用“初始化”第一次输入。初始化结构之后,您必须指定其属性值对应的遗留代码整合。遗留的原型函数被称为在这个例子中是:

  • 空白initFaultCounter (unsigned int *计数器)

  • 空白openLogFile (void * * fid)

  • 空白incAndLogFaultCounter (void *支撑材,unsigned int *柜台,双时间)

  • 空白closeLogFile (void * * fid)

打开模型和文件,单击开放模式。遗留源代码文件中找到your_types.h,fault.h,fault.c

% sldemo_sfun_faultdef = legacy_code (“初始化”);def.SFunctionName =“sldemo_sfun_fault”;def.InitializeConditionsFcnSpec =“initFaultCounter (uint32 work2 [1])”;def.StartFcnSpec =“openLogFile (void * * work1)”;def.OutputFcnSpec =“incAndLogFaultCounter (void * work1, uint32 work2[1],双u1)”;def.TerminateFcnSpec =“closeLogFile (void * * work1)”;def.HeaderFiles = {“fault.h”};def.SourceFiles = {“fault.c”};def.IncPaths = {“sldemo_lct_src”};def.SrcPaths = {“sldemo_lct_src”};def.Options。useTlcWithAccel = false;

生成和编译期间使用模拟的功能

函数legacy_code再次与第一个输入()设置为“generate_for_sim”为了自动生成和编译C-MEX s函数根据提供的描述输入参数“def”。此功能用于调用遗留功能模拟。s函数的源代码中找到该文件sldemo_sfun_fault.c

legacy_code (“generate_for_sim”def);
# # #开始编译sldemo_sfun_fault墨西哥人(“我/ tmp / Bdoc22b_2134332_1893982 / tpad1bf7eb simulin金宝appk_features-ex33158503 / sldemo_lct_src ', ' i / tmp / Bdoc22b_2134332_1893982 / tpad1bf7eb / simulink_features-ex33158503 ', ' c ', ' -outdir ', ' / tmp / Bdoc22b_2134332_1893982 / tpcc34405c_fed0_478e_af41_0f3efb5ac721 ', ' / tmp / Bdoc22b_2134332_1893982 / tpad1bf7eb simulink_features-ex33158503 / sldemo_lct_src fault.c”)建设与gcc。墨西哥人成功完成。墨西哥人(“sldemo_sfun_fault。c ', ' - i / tmp / Bdoc22b_2134332_1893982 / tp金宝appad1bf7eb / simulink_features-ex33158503 / sldemo_lct_src”、“我/ tmp / Bdoc22b_2134332_1893982 / tpad1bf7eb simulink_features-ex33158503”、“/ tmp / Bdoc22b_2134332_1893982 / tpcc34405c_fed0_478e_af41_0f3efb5ac721 fault.o”)建设与“gcc”。墨西哥人成功完成。# # #完成编译sldemo_sfun_fault # # #退出

生成一个rtwmakecfg。m文件代码生成

TLC创建块文件后,函数legacy_code()又可被称为第一个输入设置为“rtwmakecfg_generate”以产生rtwmakecfg。m文件通过仿真软件支金宝app持代码生成®编码器™。金宝app生成rtwmakecfg。m文件如果所需的源和头文件S-functions S-functions不在同一个目录,和您想要添加这些依赖项的代码生成过程中产生的makefile。

注意:完成这一步只有如果你要模拟模型在加速模式。

legacy_code (“rtwmakecfg_generate”def);

生成一个蒙面的s函数调用生成的功能块

后C-MEX s函数源代码被编译,函数legacy_code()又可被称为第一个输入设置为“slblock_generate”为了生成一个蒙面的功能块,配置为称之为功能。块被放置在一个新的模型和可以复制到现有的模型。

% legacy_code (slblock_generate, def);

集成遗留代码

模型sldemo_lct_start_term显示了遗留代码集成。子系统TestFixpt作为利用遗留C函数调用,和比较函数的输出范围的输出内置模型®产品块;金宝app结果应该是相同的。

open_system (“sldemo_lct_start_term”)open_system (“sldemo_lct_start_term / TestFault”)sim卡(“sldemo_lct_start_term”);

另请参阅