efi/tpm: Remove unused functions and structures
Although the tpm_execute() series of functions are defined they are not used anywhere. Several structures in the include/grub/efi/tpm.h header file are not used too. There is even nonexistent grub_tpm_init() declaration in this header. Delete all that unneeded stuff. If somebody needs the functionality implemented in the dropped code then he/she can re-add it later. Now it needlessly increases the GRUB code/image size. Signed-off-by: Tianjia Zhang <tianjia.zhang@linux.alibaba.com> Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
This commit is contained in:
		
							parent
							
								
									de094060ac
								
							
						
					
					
						commit
						6efd04f314
					
				
					 2 changed files with 0 additions and 138 deletions
				
			
		|  | @ -119,103 +119,6 @@ grub_tpm_handle_find (grub_efi_handle_t *tpm_handle, | |||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_tpm1_execute (grub_efi_handle_t tpm_handle, | ||||
|                    PassThroughToTPM_InputParamBlock *inbuf, | ||||
|                    PassThroughToTPM_OutputParamBlock *outbuf) | ||||
| { | ||||
|   grub_efi_status_t status; | ||||
|   grub_efi_tpm_protocol_t *tpm; | ||||
|   grub_uint32_t inhdrsize = sizeof (*inbuf) - sizeof (inbuf->TPMOperandIn); | ||||
|   grub_uint32_t outhdrsize = | ||||
|     sizeof (*outbuf) - sizeof (outbuf->TPMOperandOut); | ||||
| 
 | ||||
|   tpm = grub_efi_open_protocol (tpm_handle, &tpm_guid, | ||||
| 				GRUB_EFI_OPEN_PROTOCOL_GET_PROTOCOL); | ||||
| 
 | ||||
|   if (!grub_tpm1_present (tpm)) | ||||
|     return 0; | ||||
| 
 | ||||
|   /* UEFI TPM protocol takes the raw operand block, no param block header. */ | ||||
|   status = efi_call_5 (tpm->pass_through_to_tpm, tpm, | ||||
| 		       inbuf->IPBLength - inhdrsize, inbuf->TPMOperandIn, | ||||
| 		       outbuf->OPBLength - outhdrsize, outbuf->TPMOperandOut); | ||||
| 
 | ||||
|   switch (status) | ||||
|     { | ||||
|     case GRUB_EFI_SUCCESS: | ||||
|       return 0; | ||||
|     case GRUB_EFI_DEVICE_ERROR: | ||||
|       return grub_error (GRUB_ERR_IO, N_("Command failed")); | ||||
|     case GRUB_EFI_INVALID_PARAMETER: | ||||
|       return grub_error (GRUB_ERR_BAD_ARGUMENT, N_("Invalid parameter")); | ||||
|     case GRUB_EFI_BUFFER_TOO_SMALL: | ||||
|       return grub_error (GRUB_ERR_BAD_ARGUMENT, | ||||
| 			 N_("Output buffer too small")); | ||||
|     case GRUB_EFI_NOT_FOUND: | ||||
|       return grub_error (GRUB_ERR_UNKNOWN_DEVICE, N_("TPM unavailable")); | ||||
|     default: | ||||
|       return grub_error (GRUB_ERR_UNKNOWN_DEVICE, N_("Unknown TPM error")); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_tpm2_execute (grub_efi_handle_t tpm_handle, | ||||
|                    PassThroughToTPM_InputParamBlock *inbuf, | ||||
|                    PassThroughToTPM_OutputParamBlock *outbuf) | ||||
| { | ||||
|   grub_efi_status_t status; | ||||
|   grub_efi_tpm2_protocol_t *tpm; | ||||
|   grub_uint32_t inhdrsize = sizeof (*inbuf) - sizeof (inbuf->TPMOperandIn); | ||||
|   grub_uint32_t outhdrsize = | ||||
|     sizeof (*outbuf) - sizeof (outbuf->TPMOperandOut); | ||||
| 
 | ||||
|   tpm = grub_efi_open_protocol (tpm_handle, &tpm2_guid, | ||||
| 				GRUB_EFI_OPEN_PROTOCOL_GET_PROTOCOL); | ||||
| 
 | ||||
|   if (!grub_tpm2_present (tpm)) | ||||
|     return 0; | ||||
| 
 | ||||
|   /* UEFI TPM protocol takes the raw operand block, no param block header. */ | ||||
|   status = efi_call_5 (tpm->submit_command, tpm, | ||||
| 		       inbuf->IPBLength - inhdrsize, inbuf->TPMOperandIn, | ||||
| 		       outbuf->OPBLength - outhdrsize, outbuf->TPMOperandOut); | ||||
| 
 | ||||
|   switch (status) | ||||
|     { | ||||
|     case GRUB_EFI_SUCCESS: | ||||
|       return 0; | ||||
|     case GRUB_EFI_DEVICE_ERROR: | ||||
|       return grub_error (GRUB_ERR_IO, N_("Command failed")); | ||||
|     case GRUB_EFI_INVALID_PARAMETER: | ||||
|       return grub_error (GRUB_ERR_BAD_ARGUMENT, N_("Invalid parameter")); | ||||
|     case GRUB_EFI_BUFFER_TOO_SMALL: | ||||
|       return grub_error (GRUB_ERR_BAD_ARGUMENT, | ||||
| 			 N_("Output buffer too small")); | ||||
|     case GRUB_EFI_NOT_FOUND: | ||||
|       return grub_error (GRUB_ERR_UNKNOWN_DEVICE, N_("TPM unavailable")); | ||||
|     default: | ||||
|       return grub_error (GRUB_ERR_UNKNOWN_DEVICE, N_("Unknown TPM error")); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| grub_err_t | ||||
| grub_tpm_execute (PassThroughToTPM_InputParamBlock *inbuf, | ||||
| 		  PassThroughToTPM_OutputParamBlock *outbuf) | ||||
| { | ||||
|   grub_efi_handle_t tpm_handle; | ||||
|   grub_uint8_t protocol_version; | ||||
| 
 | ||||
|   /* Absence of a TPM isn't a failure. */ | ||||
|   if (!grub_tpm_handle_find (&tpm_handle, &protocol_version)) | ||||
|     return 0; | ||||
| 
 | ||||
|   if (protocol_version == 1) | ||||
|     return grub_tpm1_execute (tpm_handle, inbuf, outbuf); | ||||
|   else | ||||
|     return grub_tpm2_execute (tpm_handle, inbuf, outbuf); | ||||
| } | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_tpm1_log_event (grub_efi_handle_t tpm_handle, unsigned char *buf, | ||||
| 		     grub_size_t size, grub_uint8_t pcr, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue