英特尔-TSX:为什么rtm失败?

问题描述

我是使用Intel-TSX的新手。因此,请纠正我的任何术语/概念错误

我正在尝试使用here中的Polarssl库编写自定义rsa引擎(我知道它很旧,但是我很容易理解)。我有以下代码

result=-1;
unsigned block;

int key_len= 128;

while(result!=1){
    if ((block = _xbegin()) == _XBEGIN_STARTED) {
        if( rsa_pkcs1_decrypt( &rsa_polar,&myrand,NULL,RSA_PRIVATE,&key_len,from,decrypt_plaintext,sizeof(decrypt_plaintext) ) != 0 )
            exit(0);
        rsa_free(&rsa_polar);
        result=1;
        _xend();
    }else{
        printf("RTM 2: Transaction Failed\n");
        printf("status is %ld\n",block);
       
    }
    printf("Block 2: Result is %d\n",result);
}

rtm块中的代码不起作用。但是,相同的代码在rtm块之外起作用。运行代码后,我得到以下输出

.
.
RTM 2: Transaction Failed
status is 0
Block 2: Result is -1
. 
.

有关如何解决问题的帮助/建议?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)