马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?注册
x
有这样一个设计,reg3的异步置位和异步复位(SN,RN)分别直接来自于reg1和reg2(异步置位和异步复位不能同时有效,所以SN和RN不能同时为0)。Formality在解析RTL的时候自动在reg1和reg2——也就是reg3的SN和RN端添加了逻辑,保证SN和RN不能出现同时为0的情况(我看Formality的逻辑图是这样的)。但是在综合后的网表中,并没有这种处理,也就是说reg3的SN和RN是直接来自于reg1和reg2。这样reg1和reg2就会出现同时为0的情况,从而导致formality验证结果是错误的。其实reg1和reg2在电路里面已经通过置位和复位作了处理,保证不会同时输出0。
不知有什么方法可以让formality通过这种验证。 我的想法是不让reg1和reg2的Q端产生同时输出0的向量,但是存在01,10,11这三个向量 看了formality的user guide,里面有讲实用create_constraint_type创建约束,实用set_constraint施加用户创建的约束的情况,但不知道怎么做。特此请教。
有更好的办法更好。 |