主要内容

在遗留功能持久记忆

这个例子向您展示了如何使用遗留代码工具集成遗留C函数与特定于持久的记忆。

遗留代码工具允许您:

  • 提供遗留功能规范,

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

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

提供遗留功能规范

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

空白memory_bus_init (COUNTERBUS * mem、int32_T upper_sat int32_T lower_sat);

空白memory_bus_step (COUNTERBUS *输入、COUNTERBUS * mem COUNTERBUS *输出);

mem是一个特定于持久内存申请一个集成步骤延迟。COUNTERBUS是一个结构体类型定义中定义counterbus.h和实现金宝appSimulink.Bus对象的基本工作空间。遗留源代码文件中找到memory_bus.hmemory_bus.c

evalin (“基地”,“负载sldemo_lct_data.mat”)% sldemo_sfun_workdef = legacy_code (“初始化”);def.SFunctionName =“sldemo_sfun_work”;def.InitializeConditionsFcnSpec =“空白memory_bus_init (COUNTERBUS work1 [1], int32 p1, int32 p2)”;def.OutputFcnSpec =“空白memory_bus_step (COUNTERBUS u1 [1], COUNTERBUS work1 [1], COUNTERBUS y1 [1])”;def.HeaderFiles = {“memory_bus.h”};def.SourceFiles = {“memory_bus.c”};def.IncPaths = {“sldemo_lct_src”};def.SrcPaths = {“sldemo_lct_src”};

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

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

legacy_code (“generate_for_sim”def);
# # #开始编译sldemo_sfun_work墨西哥人(“我/ tmp / Bdoc22b_2134332_1893343 / tpe903b9e7 simulin金宝appk_features-ex40483229 / sldemo_lct_src ', ' i / tmp / Bdoc22b_2134332_1893343 / tpe903b9e7 / simulink_features-ex40483229 ', ' c ', ' -outdir ', ' / tmp / Bdoc22b_2134332_1893343 / tp2ece1a81_6813_4a8d_ac3b_133f3315f432 ', ' / tmp / Bdoc22b_2134332_1893343 / tpe903b9e7 simulink_features-ex40483229 / sldemo_lct_src memory_bus.c”)建设与gcc。墨西哥人成功完成。墨西哥人(“sldemo_sfun_work。c ', ' - i / tmp / Bdoc22b_2134332_1893343 / tp金宝appe903b9e7 / simulink_features-ex40483229 / sldemo_lct_src”、“我/ tmp / Bdoc22b_2134332_1893343 / tpe903b9e7 simulink_features-ex40483229”、“/ tmp / Bdoc22b_2134332_1893343 / tp2ece1a81_6813_4a8d_ac3b_133f3315f432 memory_bus.o”)建设与“gcc”。墨西哥人成功完成。# # #完成编译sldemo_sfun_work # # #退出

生成一个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_work显示了遗留代码集成。的子系统memory_bus作为利用遗留C函数调用。

open_system (“sldemo_lct_work”)open_system (“sldemo_lct_work / memory_bus”)sim卡(“sldemo_lct_work”)
ans =仿金宝app真软件。SimulationOutput: ScopeDataA: [11 x3双]吹捧:x1双[11]SimulationMetadata: [1 x1仿真软件。金宝appSimulationMetadata] ErrorMessage (0 x0 char):

另请参阅