mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 19:50:20 +00:00 
			
		
		
		
	 c749ba912e
			
		
	
	
		c749ba912e
		
	
	
	
	
		
			
			Add internal kernel tpm_send() command used to seal/unseal keys. Changelog: - replaced module_put in tpm_send() with new tpm_chip_put() wrapper (suggested by David Howells) - Make tpm_send() cmd argument a 'void *' (suggested by David Howells) Signed-off-by: David Safford <safford@watson.ibm.com> Signed-off-by: Mimi Zohar <zohar@us.ibm.com> Acked-by: David Howells <dhowells@redhat.com> Acked-by: Serge E. Hallyn <serge.hallyn@canonical.com> Signed-off-by: James Morris <jmorris@namei.org>
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2004,2007,2008 IBM Corporation
 | |
|  *
 | |
|  * Authors:
 | |
|  * Leendert van Doorn <leendert@watson.ibm.com>
 | |
|  * Dave Safford <safford@watson.ibm.com>
 | |
|  * Reiner Sailer <sailer@watson.ibm.com>
 | |
|  * Kylene Hall <kjhall@us.ibm.com>
 | |
|  * Debora Velarde <dvelarde@us.ibm.com>
 | |
|  *
 | |
|  * Maintained by: <tpmdd_devel@lists.sourceforge.net>
 | |
|  *
 | |
|  * Device driver for TCG/TCPA TPM (trusted platform module).
 | |
|  * Specifications at www.trustedcomputinggroup.org
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  */
 | |
| #ifndef __LINUX_TPM_H__
 | |
| #define __LINUX_TPM_H__
 | |
| 
 | |
| /*
 | |
|  * Chip num is this value or a valid tpm idx
 | |
|  */
 | |
| #define	TPM_ANY_NUM 0xFFFF
 | |
| 
 | |
| #if defined(CONFIG_TCG_TPM) || defined(CONFIG_TCG_TPM_MODULE)
 | |
| 
 | |
| extern int tpm_pcr_read(u32 chip_num, int pcr_idx, u8 *res_buf);
 | |
| extern int tpm_pcr_extend(u32 chip_num, int pcr_idx, const u8 *hash);
 | |
| extern int tpm_send(u32 chip_num, void *cmd, size_t buflen);
 | |
| #else
 | |
| static inline int tpm_pcr_read(u32 chip_num, int pcr_idx, u8 *res_buf) {
 | |
| 	return -ENODEV;
 | |
| }
 | |
| static inline int tpm_pcr_extend(u32 chip_num, int pcr_idx, const u8 *hash) {
 | |
| 	return -ENODEV;
 | |
| }
 | |
| static inline int tpm_send(u32 chip_num, void *cmd, size_t buflen) {
 | |
| 	return -ENODEV;
 | |
| }
 | |
| #endif
 | |
| #endif
 |