Chinaunix首页 | 论坛 | 博客
  • 博客访问: 52713
  • 博文数量: 5
  • 博客积分: 1434
  • 博客等级: 上尉
  • 技术积分: 73
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-15 10:59
文章分类
文章存档

2011年(1)

2010年(1)

2009年(3)

我的朋友

分类: 网络与安全

2009-05-18 22:14:08

tpm emulator环境搭建

作者:浪迹天涯

1、安装环境准备

1.1内核

Linux内核2.6.12版本及以上,提供了对tpm芯片的支持,下载地址:

1.2算法库支持

Gmplib库,提供一些密码学算法的支持,下载地址:

1.3 Tpm_emulator软件

Tpm_emulator模拟tpm芯片,相当于一个虚拟的芯片,目前最高版本0.5.1,下载地址:https://developer.berlios.de/project/showfiles.php?group_id=2491

1.4 Tss软件栈

Tss软件栈包括Trousersgrub-imaopenssl tpm enginetpm keyringtpm-toolstrousers软件包提供一些tpmAPI函数,这里只安装trousers软件包,下载地址:

Trousers安装所需环境:

软件要求: 版本查看命令:

automake > 1.4   automake --version

   autoconf > 1.4 autoconf --version

  Pkgconfig pkg-config --version

   Libtool rpm -qa | grep libtool 

gtk2-devel pkg-config --list-all |grep gtk (查看是否安装了gtk) 

   openssl-devel >= 0.9.8 openssl version -a//redhat as4.7 openssl版本 0.9.7a

安装openssl-0.9.8以及它所依赖的glibc2.4软件下载地址:

安装、卸载命令:rpm -ivh/-e --enforce --nodeps  XXXX

2、软件安装

2.1内核安装

#make menuconfig

在内核配置文件中选中如下参数即可将TPM驱动编入内核。

Device Driver->

Character Device->

[*] TPM Hardware Support->

[*] TPM Interface Specification 1.2 Interface

#make bzImage; make modules; make modules_install; make install

2.2 Gmplib安装

# ./configure

# make

# make check

# make install

2.3 Tpm_emulator安装

# cd /usr/src/linux  当前内核的源码目录

# zcat /proc/config.gz > .Config  保持内核配置文件与原来的相同,若没有config.Gz文件,直接用make menuconfig生成.Config文件。

# make oldconfig

# make modules_prepare 

# tar -xvzf tpm_emulator-X.Y.tar.gz

# cd tpm_emulator-X.Y

# make

# make install

Make install出现错误:

make[1]: Entering directory `/home/akshay/tmp/tpm_emulator-0.5.1/tpmd'

install -m 755 -o tss -g tss -d /var/lib/tpm

install: invalid user `tss'

解决办法:将make install改为:sudo make TPMD_USER=root TPMD_GROUP=root install

初始化

#tpmd deactivated

#killall tpmd

#tpmd clear

#rm /var/run/tpm/tpmd_socket:0 (出现failedaddress already in use 时执行它)

启动软TPM

#modprobe tpmd_dev (如果出现FATAL: Module tpmd_dev not found,则先运行depmod -a

#tpmd -f -d            tpmd -h查看启动参数)

2.3 TSS安装

2.3.1解压Trousers软件包

2.3.2重定向tddl

由于使用TPM模拟器,在编译trousers前需要将其以来的tddl库改为TPM模拟器提供的tddl

修改 ./src/tcsd/Makefile.am 4行:

tcsd_LDADD=../tcs/libtcs.a ../tddl/libtddl.a –lpthread 

为:

tcsd_LDADD=../tcs/libtcs.a /usr/lib/libtddl.so –lpthread

修改 ./src/tcsd/Makefile.in 59行:

tcsd_DEPENDENCIES = ../tcs/libtcs.a ../tddl/libtddl.a

为:

tcsd_DEPENDENCIES = ../tcs/libtcs.a /usr/lib/libtddl.so

2.3.3修改Trousers Bug

修改 ./src/include/obj_context.h 79行:

struct tcs_api_table *obj_context_get_tcs_api();

为:

struct tcs_api_table *obj_context_get_tcs_api(UINT32);

2.3.4编译,安装

#sh bootstrap.sh

#./configure –prefix=/usr

#make

#make install

2.3.5安装tpm-tools软件包

#sh bootstrap.sh

#./configure

#make

#make install

2.3.6启动Trousers

Tcsd

/tpm_emulator-0.5/tddl# make test_tddl   (测试)

/tpm_emulator-0.5/tddl# ./test_tddl(此测试程序用到了tpm-tools的相关内容)

阅读(20204) | 评论(25) | 转发(0) |
0

上一篇:没有了

下一篇:selinux原理介绍

给主人留下些什么吧!~~

小牧233332015-05-02 13:25:51

dongfs_love:终于到了传说中的“tpmd.c:370: Debug: waiting for connections..."这个地方了

到这个地方后怎么办啊,它一直不会停下来

回复 | 举报

lhdboy19882012-10-13 20:32:55

chinaunix网友: [root@happy sbin]# tcsd -fTCSD TCS ERROR: TCS GetCapability failed with result = 0x1c为什么会出现这种情况呢?该怎么解决?具体情况给你发邮件了,期待着.....
这个问题同样是由于上次启动TPM没有正常退出,并且这次以默认的SAVE方式启动,进而自检不通过造成的。
这个地方把
#tpmd -f -d  (如果不指定,默认的是save方式)
换成
#tpmd -f -d  clear

lhdboy19882012-10-13 20:29:05

chinaunix网友: 另外我还出现了一个问题,就是在运行tcsd的时候,出现TCSD TDDL ERROR: Could not find a device to open!我用cat /proc/modules发现我的tpm已经加载了。上面显.....
虽然tpmd_dev和/dev/tpm已经有了,但是守护进程并没有开启,使用如下命令开启之后就可以了:
#tpmd -f -d  clear
然后新打开一个终端,在里面执行
sudo tcsd -e -f
或其他测试程序就可以成功

lhdboy19882012-10-13 20:25:46

不懂笙瑟: 我出现的问题是/tpm/tpm_startup.c:87: Error: restoring permanent data failed
请问,你现在知道大概是什么问题了吗?
多谢!.....
你好,我也是刚开始研究tpm_emulator。出现这个问题至少说明tpm_emulator已经正确安装,只是如何使用的问题。
这个问题解决了,参考了如下文章。http://blog.csdn.net/cicisensy/article/details/5291569
解决方法在我的评论中有,解决方法就是在“启动软TPM”这个地方把
#tpmd -f -d
换成
#tpmd -f -d  clea

不懂笙瑟2012-05-17 16:11:58

wqqs0801: /tpm/tpm_startup.c:83: Error: restoring permanent data failed
tpmd.c:370: Debug: waiting for connections...
tpmd.c:370: Debug: waiting for connection.....
我出现的问题是/tpm/tpm_startup.c:87: Error: restoring permanent data failed
请问,你现在知道大概是什么问题了吗?
多谢!