/*设置TPM命令格式*/

ssize_t tpm_getcap(struct device *dev, __be32 subcap_id, cap_t *cap,

const char *desc)

{

struct tpm_cmd_t tpm_cmd;

int rc;

struct tpm_chip *chip = dev_get_drvdata(dev);

tpm_cmd.header.in = tpm_getcap_header;

if (subcap_id == CAP_VERSION_1_1 || subcap_id == CAP_VERSION_1_2) {

tpm_cmd.params.getcap_in.cap = subcap_id;

/*subcap field not necessary */

tpm_cmd.params.getcap_in.subcap_size = cpu_to_be32(0);

tpm_cmd.header.in.length -= cpu_to_be32(sizeof(__be32));

} else {

if (subcap_id == TPM_CAP_FLAG_PERM ||

subcap_id == TPM_CAP_FLAG_VOL)

tpm_cmd.params.getcap_in.cap = TPM_CAP_FLAG;

else

tpm_cmd.params.getcap_in.cap = TPM_CAP_PROP;

tpm_cmd.params.getcap_in.subcap_size = cpu_to_be32(4);

tpm_cmd.params.getcap_in.subcap = subcap_id;

}

rc = transmit_cmd(chip, &tpm_cmd, TPM_INTERNAL_RESULT_SIZE, desc);

if (!rc)

*cap = tpm_cmd.params.getcap_out.cap;

return rc;

}

/*TPM设备自检,成功返回0*/

static int tpm_continue_selftest(struct tpm_chip *chip)

{

int rc;

struct tpm_cmd_t cmd;

cmd.header.in = continue_selftest_header;

rc = transmit_cmd(chip, &cmd, CONTINUE_SELFTEST_RESULT_SIZE,

"continue selftest");

return rc;

}

/*返回tpm设备的序号,对应/dev/tpm#中#的值*/

static struct tpm_chip *tpm_chip_find_get(int chip_num)

{

struct tpm_chip *pos, *chip = NULL;

rcu_read_lock();

list_for_each_entry_rcu(pos, &tpm_chip_list, list) {

if (chip_num != TPM_ANY_NUM && chip_num != pos->dev_num)

continue;

if (try_module_get(pos->dev->driver->owner)) {

chip = pos;

break;

}

}

rcu_read_unlock();

return chip;

}

/*读取TPM设备中平台配置寄存器中的数据*/

static int __tpm_pcr_read(struct tpm_chip *chip, int pcr_idx, u8 *res_buf)

{

int rc;

struct tpm_cmd_t cmd;

cmd.header.in = pcrread_header;

cmd.params.pcrread_in.pcr_idx = cpu_to_be32(pcr_idx);

rc = transmit_cmd(chip, &cmd, READ_PCR_RESULT_SIZE,

"attempting to read a pcr value");

if (rc == 0)

memcpy(res_buf, cmd.params.pcrread_out.pcr_result,

TPM_DIGEST_SIZE);

return rc;

}

/*读取TPM设备中平台配置寄存器中的数据,对__tpm_pcr_read()函数的进一步封装*/

int tpm_pcr_read(u32 chip_num, int pcr_idx, u8 *res_buf)

{

struct tpm_chip *chip;

int rc;

/*获取tpm设备序号*/

chip = tpm_chip_find_get(chip_num);

if (chip == NULL)

return -ENODEV;

/*读取pcr中的数据*/

rc = __tpm_pcr_read(chip, pcr_idx, res_buf);

tpm_chip_put(chip);

return rc;

}

/*扩充、更新平台配置寄存器pcr中的数据*/

int tpm_pcr_extend(u32 chip_num, int pcr_idx, const u8 *hash)

{

struct tpm_cmd_t cmd;

int rc;

struct tpm_chip *chip;

chip = tpm_chip_find_get(chip_num);

if (chip == NULL)

return -ENODEV;

cmd.header.in = pcrextend_header;

cmd.params.pcrextend_in.pcr_idx = cpu_to_be32(pcr_idx);

memcpy(cmd.params.pcrextend_in.hash, hash, TPM_DIGEST_SIZE);

rc = transmit_cmd(chip, &cmd, EXTEND_PCR_RESULT_SIZE,

"attempting extend a PCR value");

tpm_chip_put(chip);

return rc;

}

/*12.www.qixoo.qixoo.com/在接受下次命令前,TPM设备状态自检。当检测状态成功可以接受命令时,返回0*/

int tpm_do_selftest(struct tpm_chip *chip)

{

int rc;

unsigned int loops;

unsigned int delay_msec = 1000;

unsigned long duration;

struct tpm_cmd_t cmd;

duration = tpm_calc_ordinal_duration(chip, TPM_ORD_CONTINUE_SELFTEST);

loops = jiffies_to_msecs(duration) / delay_msec;

rc = tpm_continue_selftest(chip);

/*在挂起或恢复期间,没有TPM设备驱动,可能失败返回10 (BAD_ORDINAL)或者28 (FAILEDSELFTEST)*/

if (rc)

return rc;

do {

/* 尝试读取pcr中的数据 */

cmd.header.in = pcrread_header;

cmd.params.pcrread_in.pcr_idx = cpu_to_be32(0);

rc = tpm_transmit(chip, (u8 *) &cmd, READ_PCR_RESULT_SIZE);

if (rc < TPM_HEADER_SIZE)

return -EFAULT;

rc = be32_to_cpu(cmd.header.out.return_code);

if (rc == TPM_ERR_DISABLED || rc == TPM_ERR_DEACTIVATED) {

dev_info(chip->dev, "TPM is disabled/deactivated (0x%X)\n", rc);

/*TPM状态是disabled 或 deactivated,TPM设备驱动可以继续运行,TPM设备可以接受处理命令*/

return 0;

}

if (rc != TPM_WARN_DOING_SELFTEST)

return rc;

msleep(delay_msec);

} while (--loops > 0);

return rc;

}

/*显示设定的TPM设备执行命令的时间*/

ssize_t tpm_show_durations(struct device *dev, struct device_attribute *attr,

char *buf)

{

struct tpm_chip *chip = dev_get_drvdata(dev);

if (chip->vendor.duration[TPM_LONG] == 0)

return 0;

return sprintf(buf, "%d %d %d [%s]\n",

jiffies_to_usecs(chip->vendor.duration[TPM_SHORT]),

jiffies_to_usecs(chip->vendor.duration[TPM_MEDIUM]),

jiffies_to_usecs(chip->vendor.duration[TPM_LONG]),

chip->vendor.duration_adjusted

? "adjusted" : "original");

}

/*显示设定的超时时间值*/

ssize_t tpm_show_timeouts(struct device *dev, struct device_attribute *attr,

char *buf)

{

struct tpm_chip *chip = dev_get_drvdata(dev);

return sprintf(buf, "%d %d %d %d [%s]\n",

jiffies_to_usecs(chip->vendor.timeout_a),

jiffies_to_usecs(chip->vendor.timeout_b),

jiffies_to_usecs(chip->vendor.timeout_c),

jiffies_to_usecs(chip->vendor.timeout_d),

chip->vendor.timeout_adjusted

? "adjusted" : "original");

}

/*取消TPM设备操作*/

ssize_t tpm_store_cancel(struct device *dev, struct device_attribute *attr,

const char *buf, size_t count)

{

struct tpm_chip *chip = dev_get_drvdata(dev);

if (chip == NULL)

return 0;

/*调用tpm_chip结构体中vendor字段指向的tpm_vendor_specific 结构体中的cancel函数成员*/

chip->vendor.cancel(chip);

return count;

}

Linux可信计算机制模块详细分析之核心文件分析(8)tpm.c核心代码注释(中)的更多相关文章

  1. Yii2.0源码分析之——控制器文件分析(Controller.php)创建动作、执行动作

    在Yii中,当请求一个Url的时候,首先在application中获取request信息,然后由request通过urlManager解析出route,再在Module中根据route来创建contr ...

  2. CI核心文件分析之基准测试类 (Benchmark.php)

    <?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); /** * CodeIgniter * * ...

  3. 性能测试分析工具nmon文件分析时报错解决办法

    1.使用nmon analyzer V334.xml分析数据时,如果文件过大,可以修改Analyser页签中的INTERVALS的最大值: 2.查找生成的nmon文件中包含的nan,删掉这些数据(需要 ...

  4. Linux强制访问控制机制模块分析之mls_type.h

    2.4.2 mls_type.h 2.4.2.1文件描述 对于mls_type.h文件,其完整文件名为security/selinux/ss/mls_types.h,该文件定义了MLS策略使用的类型. ...

  5. Linux内核OOM机制的详细分析(转)

    Linux 内核 有个机制叫OOM killer(Out-Of-Memory killer),该机制会监控那些占用内存过大,尤其是瞬间很快消耗大量内存的进程,为了 防止内存耗尽而内核会把该进程杀掉.典 ...

  6. 【内核】linux内核启动流程详细分析

    Linux内核启动流程 arch/arm/kernel/head-armv.S 该文件是内核最先执行的一个文件,包括内核入口ENTRY(stext)到start_kernel间的初始化代码, 主要作用 ...

  7. 【内核】linux内核启动流程详细分析【转】

    转自:http://www.cnblogs.com/lcw/p/3337937.html Linux内核启动流程 arch/arm/kernel/head-armv.S 该文件是内核最先执行的一个文件 ...

  8. linux 时钟源初步分析linux kernel 时钟框架详细介绍

    初步概念: 看datasheet的关于时钟与定时器的部分, FCLK供给cpu, HCLK供给AHB总线设备(存储器控制器,中断控制器.LCD控制器.DMA.USB主机控制器等), PCLK供给APB ...

  9. 【原创】Linux信号量机制分析

    背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...

随机推荐

  1. 深入理解DOM节点关系

    × 目录 [1]父级属性 [2]子级属性 [3]同级属性[4]包含方法[5]关系方法 前面的话 DOM可以将任何HTML描绘成一个由多层节点构成的结构.节点分为12种不同类型,每种类型分别表示文档中不 ...

  2. css3 transition属性

    最近打算学习css3知识,觉得css3写出来的效果好炫好酷,之前一直想要学习来着.可能之前的决心,毅力,耐心不够,所以想要重整起来,放下浮躁的心态,一步一个脚印,踏踏实实的来学习. 首先学习的是css ...

  3. fastjson 混淆注意事项

    使用fastjson 注意事项,主要表现: 1.加了符号Annotation 的实体类,一使用就会奔溃 2.当有泛型属性时,一使用就奔溃 在调试的时候不会报错,当你要打包签名混淆包的时候,就会出现上述 ...

  4. Atitit.工作流 与 规则引擎

    Atitit.工作流 与 规则引擎 1.1. 应用来说,通常分为三部分:界面.业务逻辑和存储1 1.2. 自定义操作系列1 1.3. 自定义按钮系列2 1.1. 应用来说,通常分为三部分:界面.业务逻 ...

  5. AngularJS 模块& 表单

    模块定义了一个应用程序. 模块是应用程序中不同部分的容器. 模块是应用控制器的容器. 控制器通常属于一个模块. 应用("myApp") 带有控制器 ("myCtrl&qu ...

  6. 为 suse linux 设置程序自动启动

    1.suse linux 程序自动启动 在部署面安装的的时候,重启之后需要去tomcat/bin/startup.sh 下面去执行启动脚本. 设置开机自动启动该服务    在 vim   /etc/i ...

  7. STM32C8T6 JTAG使用到PB3|PB4|PA13|PA14|PB15端口做普通IO时,需禁止JTAG!

    GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_GPIO ...

  8. 解决Ubuntu下Firefox+OpenJDK没有Java插件的问题

    如果是安装的OpenJDK,很遗憾它是没有libnpjp2.so的. 此时按照网上各种奇怪的方法都挣扎无效,但可以用icedtea插件来解决这个问题. icedtea的版本与本机安装的OpenJDK版 ...

  9. python爬虫学习(10) —— 专利检索DEMO

    这是一个稍微复杂的demo,它的功能如下: 输入专利号,下载对应的专利文档 输入关键词,下载所有相关的专利文档 0. 模块准备 首先是requests,这个就不说了,爬虫利器 其次是安装tessera ...

  10. 轻量级C#编辑器RoslynPad

    简介 RoslynPad是一个Apache 2.0协议开源的轻量级C#编辑器.支持自动完成,语法提示,修改建议等功能.很适合平时随手写个C#程序看看运行结果. 目前版本:0.10.1,无需保存也可以运 ...