tpm emulator環境搭建

1、安裝環境準備

1.1內核

Linux內核 2.6.12 版本及以上,提供了對 tpm 芯片的支持,下載地址: ftp://ftp.kernel.org/pub/linux/kernel/v2.6/

1.2算法庫支持

Gmplib庫,提供一些密碼學算法的支持,下載地址: http://gmplib.org/

1.3 Tpm_emulator軟件

Tpm_emulator模擬 tpm 芯片,相當於一個虛擬的芯片,目前最高版本 0.5.1 ,下載地址: https://developer.berlios.de/project/showfiles.php?group_id=2491

1.4 Tss軟件棧

Tss軟件棧包括 Trousers grub-ima openssl tpm engine tpm keyring tpm-tools trousers 軟件包提供一些 tpm API 函數,這裏只安裝 trousers 軟件包,下載地址: http://sourceforge.net/project/showfiles.php?group_id=126012

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 軟件下載地址: http://rpmfind.net/linux/rpm2html/search.php?

安裝、卸載命令: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 (出現failed address 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  5 9 行:

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 的相關內容)

 

 

原文地址:http://www.cublog.cn/u3/96833/showart_1932475.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章