35 lines
		
	
	
		
			750 B
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			750 B
		
	
	
	
		
			C
		
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /*
 | |
|  * Copyright 2022 Google LLC
 | |
|  * Written by Simon Glass <sjg@chromium.org>
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <dm.h>
 | |
| #include <tpm_api.h>
 | |
| #include <dm/test.h>
 | |
| #include <test/test.h>
 | |
| #include <test/ut.h>
 | |
| 
 | |
| /* Basic test of the TPM uclass */
 | |
| static int dm_test_tpm(struct unit_test_state *uts)
 | |
| {
 | |
| 	struct udevice *dev;
 | |
| 	char buf[50];
 | |
| 
 | |
| 	/* check probe success */
 | |
| 	ut_assertok(uclass_first_device_err(UCLASS_TPM, &dev));
 | |
| 	ut_assert(tpm_is_v2(dev));
 | |
| 
 | |
| 	ut_assert(tpm_report_state(dev, buf, sizeof(buf)));
 | |
| 	ut_asserteq_str("init_done=0", buf);
 | |
| 
 | |
| 	ut_assertok(tpm_init(dev));
 | |
| 
 | |
| 	ut_assert(tpm_report_state(dev, buf, sizeof(buf)));
 | |
| 	ut_asserteq_str("init_done=1", buf);
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| DM_TEST(dm_test_tpm, UT_TESTF_SCAN_FDT);
 |