亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tpm-tis-device

?? xen 3.2.2 源碼
??
?? 第 1 頁 / 共 3 頁
字號:
# HG changeset patch# User kaf24@localhost.localdomain# Node ID d60b709724f48397b95da3d56299213cae391789# Parent  bbcac2aea0e8196cd75a3bf6dbe57bebf8c1e5b2[QEMU] Add a TIS device model compliant to the 1.2 TPM specification.It implements all registers necessary to make the Linux TIS driverwork (tpm_tis.c). All of the basic registers supported by this type ofdevice are implemented. Also the locality selection has beenimplemented, but has not been tested. The legacy registers asdescribed in the specification are not supported.Current caveat: The device has so far not yet been integrated with thevirtual TPM available in the repository. It will require changes tothe virtual TPM spawned by the vTPM manager to offer an additional messageinterface. The TIS interface itself then needs to have an additionaltransport implemented. (see vTPMTransmit array).The relevant specification for the device model can be found here:https://www.trustedcomputinggroup.org/groups/pc_client/TCG_PCClientTPMSpecification_1-20_1-00_FINAL.pdfSigned-off-by: Stefan Berger <stefanb@us.ibm.com>Index: ioemu/Makefile.target===================================================================--- ioemu.orig/Makefile.target	2007-05-10 15:19:29.000000000 +0100+++ ioemu/Makefile.target	2007-05-10 15:19:29.000000000 +0100@@ -400,6 +400,7 @@ VL_OBJS+= piix4acpi.o VL_OBJS+= xenstore.o VL_OBJS+= xen_platform.o+VL_OBJS+= tpm_tis.o CPPFLAGS += -DHAS_AUDIO endif ifeq ($(TARGET_BASE_ARCH), ppc)Index: ioemu/hw/pc.c===================================================================--- ioemu.orig/hw/pc.c	2007-05-10 15:19:28.000000000 +0100+++ ioemu/hw/pc.c	2007-05-10 15:19:29.000000000 +0100@@ -730,6 +730,9 @@         }     } +    if (has_tpm_device())+        tpm_tis_init(&pic_set_irq_new, isa_pic, 11);+     kbd_init();     DMA_init(0); #ifdef HAS_AUDIOIndex: ioemu/hw/tpm_tis.c===================================================================--- /dev/null	1970-01-01 00:00:00.000000000 +0000+++ ioemu/hw/tpm_tis.c	2007-05-10 15:19:29.000000000 +0100@@ -0,0 +1,1128 @@+/*+ * tpm_tis.c - QEMU emulator for a 1.2 TPM with TIS interface+ *+ * Copyright (C) 2006 IBM Corporation+ *+ * Author: Stefan Berger <stefanb@us.ibm.com>+ *         David Safford <safford@us.ibm.com>+ *+ * This program is free software; you can redistribute it and/or+ * modify it under the terms of the GNU General Public License as+ * published by the Free Software Foundation, version 2 of the+ * License.+ *+ *+ * Implementation of the TIS interface according to specs at+ * https://www.trustedcomputinggroup.org/groups/pc_client/TCG_PCClientTPMSpecification_1-20_1-00_FINAL.pdf+ *+ */++#include <sys/types.h>+#include <sys/stat.h>+#include <sys/socket.h>+#include <sys/un.h>+#include <fcntl.h>+#include <errno.h>+#include "vl.h"++//#define DEBUG_TPM++#define TPM_MAX_PKT	              4096++#define VTPM_BAD_INSTANCE             (uint32_t)0xffffffff++#define TIS_ADDR_BASE                 0xFED40000++/* tis registers */+#define TPM_REG_ACCESS                0x00+#define TPM_REG_INT_ENABLE            0x08+#define TPM_REG_INT_VECTOR            0x0c+#define TPM_REG_INT_STATUS            0x10+#define TPM_REG_INTF_CAPABILITY       0x14+#define TPM_REG_STS                   0x18+#define TPM_REG_DATA_FIFO             0x24+#define TPM_REG_DID_VID               0xf00+#define TPM_REG_RID                   0xf04++#define STS_VALID                    (1 << 7)+#define STS_COMMAND_READY            (1 << 6)+#define STS_TPM_GO                   (1 << 5)+#define STS_DATA_AVAILABLE           (1 << 4)+#define STS_EXPECT                   (1 << 3)+#define STS_RESPONSE_RETRY           (1 << 1)++#define ACCESS_TPM_REG_VALID_STS     (1 << 7)+#define ACCESS_ACTIVE_LOCALITY       (1 << 5)+#define ACCESS_BEEN_SEIZED           (1 << 4)+#define ACCESS_SEIZE                 (1 << 3)+#define ACCESS_PENDING_REQUEST       (1 << 2)+#define ACCESS_REQUEST_USE           (1 << 1)+#define ACCESS_TPM_ESTABLISHMENT     (1 << 0)++#define INT_ENABLED                  (1 << 31)+#define INT_DATA_AVAILABLE           (1 << 0)+#define INT_LOCALITY_CHANGED         (1 << 2)+#define INT_COMMAND_READY            (1 << 7)++#define INTERRUPTS_SUPPORTED         (INT_LOCALITY_CHANGED | \+                                      INT_DATA_AVAILABLE   | \+                                      INT_COMMAND_READY)+#define CAPABILITIES_SUPPORTED       ((1 << 4) |            \+                                      INTERRUPTS_SUPPORTED)++enum {+  STATE_IDLE = 0,+  STATE_READY,+  STATE_COMPLETION,+  STATE_EXECUTION,+  STATE_RECEPTION+};++#define NUM_LOCALITIES   5+#define NO_LOCALITY      0xff++#define IS_VALID_LOC(x) ((x) < NUM_LOCALITIES)++#define TPM_DID          0x0001+#define TPM_VID          0x0001+#define TPM_RID          0x0001++/* if the connection to the vTPM should be closed after a successfully+   received response; set to '0' to allow keeping the connection */+#define FORCE_CLOSE      0++/* local data structures */++typedef struct TPMTx {+    int fd[2];+} tpmTx;++typedef struct TPMBuffer {+    uint8_t instance[4];      /* instance number in network byte order */+    uint8_t buf[TPM_MAX_PKT];+} __attribute__((packed)) tpmBuffer;++/* locality data */+typedef struct TPMLocal {+    uint32_t state;+    uint8_t access;+    uint8_t sts;+    uint32_t inte;+    uint32_t ints;+} tpmLoc;++/* overall state of the TPM interface; 's' marks as save upon suspension */+typedef struct TPMState {+    uint32_t offset;            /* s */+    tpmBuffer buffer;           /* s */+    uint8_t active_loc;         /* s */+    uint8_t aborting_locty;+    uint8_t next_locty;+    uint8_t irq_pending;        /* s */+    tpmLoc loc[NUM_LOCALITIES]; /* s */+    QEMUTimer *poll_timer;+    SetIRQFunc *set_irq;+    void *irq_opaque;+    int irq;+    int poll_attempts;+    uint32_t vtpm_instance;  /* vtpm inst. number; determined from xenstore*/+    int Transmitlayer;+    tpmTx tpmTx;+} tpmState;+++/* local prototypes */+static int TPM_Send(tpmState *s, tpmBuffer *buffer, uint8_t locty, char *msg);+static int TPM_Receive(tpmState *s, tpmBuffer *buffer);+static uint32_t vtpm_instance_from_xenstore(void);+static void tis_poll_timer(void *opaque);+static void tis_prep_next_interrupt(tpmState *s);+static void tis_raise_irq(tpmState *s, uint8_t locty, uint32_t irqmask);+static void close_vtpm_channel(tpmState *s, int force);+static void open_vtpm_channel(tpmState *s);+static void tis_attempt_receive(tpmState *s, uint8_t locty);++/* transport layer functions: local sockets */+static int create_local_socket(tpmState *s, uint32_t vtpm_instance);+static int write_local_socket(tpmState *s, const tpmBuffer *);+static int read_local_socket(tpmState *s, tpmBuffer *);+static int close_local_socket(tpmState *s, int force);+static int has_channel_local_socket(tpmState *s);+#define LOCAL_SOCKET_PATH      "/var/vtpm/vtpm_all.socket"+++#define NUM_TRANSPORTS 1++struct vTPM_transmit {+    int (*open) (tpmState *s, uint32_t vtpm_instance);+    int (*write) (tpmState *s, const tpmBuffer *);+    int (*read) (tpmState *s, tpmBuffer *);+    int (*close) (tpmState *s, int);+    int (*has_channel) (tpmState *s);+} vTPMTransmit[NUM_TRANSPORTS] = {+    { .open = create_local_socket,+      .write = write_local_socket,+      .read = read_local_socket,+      .close = close_local_socket,+      .has_channel = has_channel_local_socket,+    }+};+++#define IS_COMM_WITH_VTPM(s)                            \+     ((s)->Transmitlayer >= 0 &&                        \+      vTPMTransmit[(s)->Transmitlayer].has_channel(s))+++/**********************************************************************+ helper functions+ *********************************************************************/++static inline uint32_t tpm_get_size_from_buffer(const uint8_t *buffer)+{+    uint32_t len = (buffer[4] << 8) + buffer[5];+    return len;+}++static inline void tpm_initialize_instance(tpmState *s, uint32_t instance)+{+    s->buffer.instance[0] = (instance >> 24) & 0xff;+    s->buffer.instance[1] = (instance >> 16) & 0xff;+    s->buffer.instance[2] = (instance >>  8) & 0xff;+    s->buffer.instance[3] = (instance >>  0) & 0xff;+}++/*+ * open communication channel with a vTPM+ */+static void open_vtpm_channel(tpmState *s)+{+    int idx;+    /* search a usable transmit layer */+    for (idx = 0; idx < NUM_TRANSPORTS; idx++) {+        if (1 == vTPMTransmit[idx].open(s, s->vtpm_instance)) {+            /* found one */+            s->Transmitlayer = idx;+            break;+        }+    }+}++/*+ * close the communication channel with the vTPM+ */+static inline void close_vtpm_channel(tpmState *s, int force)+{+    if (1 == vTPMTransmit[s->Transmitlayer].close(s, force)) {+        s->Transmitlayer = -1;+    }+}++static inline uint8_t locality_from_addr(target_phys_addr_t addr)+{+    return (uint8_t)((addr >> 12) & 0x7);+}+++/**********************************************************************+    low-level transmission layer methods+ *********************************************************************/++/*+ * the 'open' method that creates the filedescriptor for communicating+ * only one is needed for reading and writing+ */+static int create_local_socket(tpmState *s, uint32_t vtpm_instance)+{+    int success = 1;+    if (s->tpmTx.fd[0] < 0) {+        s->tpmTx.fd[0] = socket(PF_LOCAL, SOCK_STREAM, 0);++        if (has_channel_local_socket(s)) {+            struct sockaddr_un addr;+            memset(&addr, 0x0, sizeof(addr));+            addr.sun_family = AF_LOCAL;+            strcpy(addr.sun_path, LOCAL_SOCKET_PATH);+            if (connect(s->tpmTx.fd[0],+                        (struct sockaddr *)&addr,+                        sizeof(addr)) != 0) {+                close_local_socket(s, 1);+                success = 0;+            } else {+                /* put filedescriptor in non-blocking mode for polling */+                int flags = fcntl(s->tpmTx.fd[0], F_GETFL);+                fcntl(s->tpmTx.fd[0], F_SETFL, flags | O_NONBLOCK);+            }+#ifdef DEBUG_TPM+            if (success)+                fprintf(logfile,"Successfully connected using local socket "+                                LOCAL_SOCKET_PATH ".\n");+            else+                fprintf(logfile,"Could not connect to local socket "+                                LOCAL_SOCKET_PATH ".\n");+#endif+        } else {+            success = 0;+        }+    }+    return success;+}++/*+ * the 'write' method for sending requests to the vTPM+ * four bytes with the vTPM instance number are prepended to each request+ * the locality in which the command was sent is transmitted in the+ * highest 3 bits+ */+static int write_local_socket(tpmState *s, const tpmBuffer *buffer)+{+    uint32_t size = tpm_get_size_from_buffer(buffer->buf);+    int len;++    len = write(s->tpmTx.fd[0],+                buffer->instance,+                sizeof(buffer->instance) + size);+    if (len == sizeof(buffer->instance) + size) {+        return len;+    } else {+        return -1;+    }+}++/*+ * the 'read' method for receiving of responses from the TPM+ * this function expects that four bytes with the instance number+ * are received from the vTPM+ */+static int read_local_socket(tpmState *s, tpmBuffer *buffer)+{+    int off;+#ifdef DEBUG_TPM+    fprintf(logfile, "Reading from fd %d\n", s->tpmTx.fd[0]);+#endif+    off = read(s->tpmTx.fd[0],+               buffer->instance,+               sizeof(buffer->instance)+TPM_MAX_PKT);+#ifdef DEBUG_TPM+    fprintf(logfile, "Read %d bytes\n", off);+#endif+    return off;+}++/*+ * the 'close' method+ * shut down communication with the vTPM+ * 'force' = 1 indicates that the socket *must* be closed+ * 'force' = 0 indicates that a connection may be maintained+ */+static int close_local_socket(tpmState *s, int force)+{+    if (force) {+        close(s->tpmTx.fd[0]);+#ifdef DEBUG_TPM+        fprintf(logfile,"Closed connection with fd %d\n",s->tpmTx.fd[0]);+#endif+        s->tpmTx.fd[0] = -1;+        return 1; /* socket was closed */+    }+#ifdef DEBUG_TPM+    fprintf(logfile,"Keeping connection with fd %d\n",s->tpmTx.fd[0]);+#endif+    return 0;+}++/*+ * the 'has_channel' method that checks whether there's a communication+ * channel with the vTPM+ */+static int has_channel_local_socket(tpmState *s)+{+    return (s->tpmTx.fd[0] > 0);+}++/**********************************************************************/++/*+ * read a byte of response data

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日本一区视频| 国产精品国产自产拍高清av| 97超碰欧美中文字幕| 成熟亚洲日本毛茸茸凸凹| 国产老妇另类xxxxx| 国产成人在线看| 成人激情免费视频| 91一区一区三区| 北条麻妃一区二区三区| 99久久伊人精品| 欧美三级乱人伦电影| 欧美一区二区三区在线| 日韩一区二区精品葵司在线| 久久久夜色精品亚洲| 国产精品欧美一区喷水| 亚洲图片欧美视频| 美女脱光内衣内裤视频久久网站 | 欧美国产日韩亚洲一区| 国产日韩欧美不卡在线| 亚洲欧美另类小说| 青青草一区二区三区| 国产91精品久久久久久久网曝门| 99r国产精品| 欧美一区二区视频观看视频| 日韩精品一区二区三区在线观看| 欧美激情在线一区二区三区| 玉足女爽爽91| 国产综合久久久久影院| 日本韩国欧美一区二区三区| 日韩精品中文字幕一区二区三区| 国产精品美女久久久久久2018| 一区二区三区自拍| 青娱乐精品视频在线| 91在线视频播放| 欧美成人精精品一区二区频| 欧美激情在线免费观看| 日韩精品一卡二卡三卡四卡无卡| 国产福利一区在线观看| 欧美三区免费完整视频在线观看| 久久午夜羞羞影院免费观看| 亚洲国产精品尤物yw在线观看| 国产一区二区三区综合| 欧美三级日本三级少妇99| 欧美韩国日本不卡| 青青青爽久久午夜综合久久午夜 | 免费欧美在线视频| 91麻豆精品在线观看| 精品国产一区二区三区久久影院 | 一区二区三区精品| 不卡的av电影| 日韩午夜在线影院| 亚洲.国产.中文慕字在线| 国产成人精品免费一区二区| 欧美一区午夜精品| 亚洲无人区一区| 欧美在线免费视屏| 一区二区三区在线免费观看| 国产成人av电影在线| 精品毛片乱码1区2区3区| 五月激情综合色| 欧美日韩一区二区三区高清 | 亚洲国产成人私人影院tom| 奇米综合一区二区三区精品视频| 欧美最猛黑人xxxxx猛交| 国产精品美女久久久久高潮| 国产精品18久久久久久久久久久久 | 国产日韩三级在线| 国产一区二区三区四区在线观看| 日韩一级免费观看| 九九国产精品视频| 欧美一级淫片007| 水野朝阳av一区二区三区| 91成人免费在线| 亚洲va欧美va人人爽午夜| 在线播放一区二区三区| 亚洲大尺度视频在线观看| 日韩美女一区二区三区四区| 天天色 色综合| 日韩精品一区二区三区中文精品| 奇米色一区二区| 欧美sm极限捆绑bd| 国产一区二区视频在线| 国产精品美女久久福利网站| 成人教育av在线| 136国产福利精品导航| 91蜜桃网址入口| 亚洲成人av免费| 欧美videos中文字幕| 成人综合婷婷国产精品久久| 一区二区中文字幕在线| 欧美网站一区二区| 麻豆国产精品一区二区三区| 久久精品亚洲一区二区三区浴池| 粉嫩高潮美女一区二区三区| 1024精品合集| 日韩精品最新网址| 成人美女视频在线观看| 亚洲电影在线免费观看| 欧美一区中文字幕| 国产一区二区三区在线观看精品| 国产精品久久久久久户外露出 | a级高清视频欧美日韩| 亚洲乱码中文字幕综合| 91精品国产乱| 国产一区二区免费在线| 亚洲男帅同性gay1069| 日韩女优毛片在线| 99麻豆久久久国产精品免费优播| 午夜av区久久| 中文字幕在线观看一区| 欧美一级高清片在线观看| 成人网在线播放| 蜜桃在线一区二区三区| 亚洲欧美电影一区二区| 欧美mv日韩mv亚洲| 欧美中文字幕久久| 国产福利一区二区三区视频在线| 亚洲一区二区三区自拍| 国产欧美日韩在线| 91麻豆精品91久久久久同性| 9人人澡人人爽人人精品| 免费一级欧美片在线观看| 亚洲人成人一区二区在线观看| 日韩视频在线一区二区| 91福利在线免费观看| 国产精品一区二区久激情瑜伽| 亚洲成人先锋电影| 亚洲美女少妇撒尿| 国产精品毛片无遮挡高清| 久久综合成人精品亚洲另类欧美 | 日韩精品91亚洲二区在线观看 | 久久久久久久久久电影| 91精品久久久久久蜜臀| 色老汉av一区二区三区| 99精品热视频| 99精品一区二区三区| 成人黄色小视频在线观看| 狠狠色综合色综合网络| 免费在线成人网| 三级欧美在线一区| 亚洲午夜羞羞片| 亚洲成人综合视频| 亚洲综合无码一区二区| 国产精品乱码人人做人人爱| 久久亚洲一区二区三区四区| 欧美va在线播放| 欧美mv日韩mv国产网站app| 欧美一级二级三级蜜桃| 制服丝袜亚洲精品中文字幕| 欧美日韩精品三区| 69久久99精品久久久久婷婷| 欧美日韩精品一区二区在线播放| 日本精品免费观看高清观看| 91成人免费在线| 欧美日韩国产首页在线观看| 欧美肥胖老妇做爰| 日韩免费高清av| 久久久91精品国产一区二区三区| 久久噜噜亚洲综合| 亚洲欧美影音先锋| 亚洲h在线观看| 蜜臀91精品一区二区三区| 国模套图日韩精品一区二区 | 亚洲少妇屁股交4| 一区二区三区视频在线观看| 亚洲图片欧美综合| 毛片av中文字幕一区二区| 国产自产2019最新不卡| 成人av动漫在线| 欧美日韩1234| 欧美精品一区二区三区很污很色的| 亚洲精品在线观看视频| 国产精品久久久久精k8| 一区二区三区久久久| 爽好久久久欧美精品| 国产久卡久卡久卡久卡视频精品| 国产99一区视频免费| 欧洲精品一区二区| 亚洲精品在线免费观看视频| 中文字幕一区二区三区四区| 午夜日韩在线观看| 国产成人av电影在线播放| 欧美亚洲图片小说| 亚洲精品一区二区三区99| 成人免费视频在线观看| 蜜桃视频一区二区| 色综合久久中文综合久久牛| 欧美成人性战久久| 亚洲欧美日韩国产手机在线| 久久99精品视频| 色美美综合视频| 久久综合网色—综合色88| 一区二区不卡在线播放| 国产成人免费视频| 91精品国产综合久久久久久久久久 | 99国产精品久久久久| 欧美哺乳videos| 一个色在线综合| 成人久久视频在线观看| 欧美成人官网二区|