- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试编写调用外部子程序并支持VHDL-2008 VHPI 接口(interface)和Modelsim FLI 接口(interface)的VHDL 模块。 VHDL-2008 标记外部子程序的机制是:
atrribute foreign of some_subprogram : procedure is "VHPI libname;some_subprogram";
但是 Modelsim 的 FLI 将其定义为:
attribute foreign of some_subprogram : procedure is "some_subprogram libname";
我想对这些使用相同的实体/架构对,因为所有 VHDL 都是相同的。唯一不同的是外部子程序属性。我尝试过类似的方法:
function get_foreign_attribute_string(func_name : in string; libname : in libname) return string;
attribute foreign of some_subprogram : procedure is get_foreign_attribute_string("some_subprogram", "libname");
但是 Modelsim 拒绝接受外部属性不是字符串文字的说法。
我尝试将函数插入包中,并在包主体中定义属性,但它要求将属性附加到函数声明中。
缺少声明两个包并根据工具集有选择地编译,我不确定如何实现这一点。
安迪的想法?
编辑:这是一个示例案例。
library std; -- for foriegn attribute
use std.all;
entity foo is
generic
(
SIMULATOR : integer range 0 to 1 -- 0 = Modelsim FLI, 1 = VHDL-2008 VHPI
);
end entity foo;
architecture test of foo is
function get_foreign_attribute_string(func_name : in string; libname : in string) return string is
begin
case SIMULATOR is
when 0 =>
return func_name & " " & libname;
when 1 =>
return "VHPI " & libname & ";" & func_name;
end case;
end function;
procedure some_subprogram is
begin
report "some_subprogram";
end procedure;
attribute foreign of some_subprogram : procedure is get_foreign_attribute_string("some_subprogram", "libname");
begin
end architecture test;
编辑:这是我的第一个解决方法:
library std; -- for foreign attribute
use std.all;
entity foo is
generic
(
SIMULATOR : integer range 0 to 1 -- 0 = Modelsim FLI, 1 = VHDL-2008 VHPI
);
end entity foo;
architecture test of foo is
procedure some_subprogram_mti is
begin
assert false;
end procedure some_subprogram_mti;
attribute foreign of some_subprogram_mti : procedure is "some_subprogram libname";
procedure some_subprogram_vhpi is
begin
assert false;
end procedure some_subprogram_vhpi;
attribute foreign of some_subprogram_vhpi : procedure is "VHPI libname;some_subprogram";
procedure some_subprogram is
begin
case SIMULATOR is
when 0 =>
some_subprogram_mti;
when 1 =>
some_subprogram_vhpi;
end case;
end procedure;
begin
end architecture test;
不幸的是,这也失败了,因为模拟器在精化过程中尝试绑定(bind)外部函数。并且 _vhpi
版本不会绑定(bind)。
最佳答案
并不是真正的答案,但评论太长了:
这似乎是 foreign
属性的特殊行为。因此,这段代码在 Modelsim 上运行良好:
entity ATTRIBUTE_TEST is
end entity ATTRIBUTE_TEST;
architecture ATTRIBUTE_TEST of ATTRIBUTE_TEST is
function get_foreign_attribute_string(func_name : in string; libname : in string) return string is
begin
return func_name & " " & libname;
end function;
procedure some_subprogram is
begin
report "some_subprogram";
end procedure;
attribute not_foreign : string;
attribute not_foreign of some_subprogram : procedure is get_foreign_attribute_string("some_subprogram", "libname");
begin
process
begin
report "process";
wait;
end process;
end architecture ATTRIBUTE_TEST;
1076-2008 第 14.4.1 节规定:
The elaboration of a declarative part consists of the elaboration of the declarative items, if any, in the order in which they are given in the declarative part. This rule holds for all declarative parts, with the following three exceptions:
...
c) A subprogram declarative part whose subprogram is decorated with the 'FOREIGN attribute defined in package STANDARD.
For these cases, the declarative items are not elaborated; instead, the design entity or subprogram is subject to implementation-dependent elaboration.
这似乎与这里相关。
关于vhdl - 基于通用设置VHDL外部属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35933733/
如何指示 webpack 排除所有 d3 模块? // does not work externals: { "d3-*": "d3" } 所以如果应用导入了d3-submod
这个问题在这里已经有了答案: 9年前关闭。 Possible Duplicate: What does “outer =>” really mean? 我在哪里可以找到有关信息 trait After
这是一个简单的循环,我正在尝试对性能进行基准测试。 var extremeLoop=function(n){ var time=new Date() var t=0; for(
问题+概述 下面是两个片段,其中包含最初隐藏的 div,然后通过单击 button 和 jQuery 的 .show() 显示。两个 div 都具有由外部样式表应用的 display: grid; 样
我有一个 HTML 页面和一个单独的 .js 文件,该文件包含在带有 的页面中标签。 这是我的 .js 文件: element = document.getElementById("test");
我在 linux 静态库项目中有 3 个文件,我想在两个类方法实现文件中使用的静态字段存在链接问题。我有 class1.h、class1main.cpp 和 class1utils.cpp。 clas
我正在尝试将颜色背景更改为默认背景颜色,当我点击输入框外 我尝试使用“null”或“none”但没有用? window.addEventListener('click', outsideClick);
我正在编写一个应用程序,要求用户在手机上选择各种类型的文件。我使用此代码启动文件选择器 Intent : Intent intent = new Intent(Intent.ACTION_GET_C
在 android 中,不可移动(内部)的外部存储和内部存储有什么区别?我不确定在哪里保存我的数据。我只需要保存一个人可以随时提取的游戏统计数据 谢谢 最佳答案 在许多较新的设备中,将不再有物理区别,
在 C++ 中,假设我们有这个头文件: myglobals.h #ifndef my_globals_h #define my_globals_h int monthsInYear = 12; #en
我正在尝试使用 externs 在 C++ 中连接到 Ada。这两种实现有什么区别? 实现A namespace Ada { extern "C" { int getN
这个问题在这里已经有了答案: Get selected element's outer HTML (30 个答案) 关闭 2 年前。 想象一下我们有这样的东西: Hello World 如果我们这样
假设我在模块的顶部有这个: Public Declare Function getCustomerDetails Lib "CustomerFunctions" () As Long 如果我从 VB6
我目前正在使用这段代码: var wordRandomizer = { run: function (targetElem) { var markup = this.creat
我们正在使用 SVN 试水,并以 Beanstalk 作为主机。我们的设置如下所示: 存储库:模块 模块一 模块二 模块 3 存储库:网站1 自定义网站代码 svn:对模块 1 的外部引用 svn:对
有没有办法在负载均衡器中设置自动外部 IP 分配给像谷歌这样的服务? 我在裸机上运行 Kubernetes。 谢谢 最佳答案 使用 nodePort 类型的服务,它会将您的服务绑定(bind)到所有节
是否有可能在 Controller 之外使用 generateUrl() 方法? 我尝试在带有 $this->get('router') 的自定义存储库类中使用它,但它没有用。 更新 我在这里找到了一
我目前正在尝试通过 Webpack 外部对象外部化 Angular 依赖项来缩短构建时间。到目前为止,我已经为 React 和其他小库实现了这一目标。 如果我只是移动 '@angular/compil
我想创建一个自动应用其他插件的插件(外部插件)。这要求在我称为“应用插件”之前为插件设置构建脚本依赖项。但是似乎我无法在插件中添加buildscript依赖项,或者得到了: 您不能更改处于未解析状态的
我是R包的创建者EnvStats . 有一个我经常使用的函数,叫做 stripChart .我刚开始学习ggplot2 ,并在过去几天里仔细研究了 Hadley 的书、Winston 的书、Stack
我是一名优秀的程序员,十分优秀!