xref: /aosp_15_r20/external/flashrom/tests/lifecycle.c (revision 0d6140be3aa665ecc836e8907834fcd3e3b018fc)
1*0d6140beSAndroid Build Coastguard Worker /*
2*0d6140beSAndroid Build Coastguard Worker  * This file is part of the flashrom project.
3*0d6140beSAndroid Build Coastguard Worker  *
4*0d6140beSAndroid Build Coastguard Worker  * Copyright 2021 Google LLC
5*0d6140beSAndroid Build Coastguard Worker  *
6*0d6140beSAndroid Build Coastguard Worker  * This program is free software; you can redistribute it and/or modify
7*0d6140beSAndroid Build Coastguard Worker  * it under the terms of the GNU General Public License as published by
8*0d6140beSAndroid Build Coastguard Worker  * the Free Software Foundation; version 2 of the License.
9*0d6140beSAndroid Build Coastguard Worker  *
10*0d6140beSAndroid Build Coastguard Worker  * This program is distributed in the hope that it will be useful,
11*0d6140beSAndroid Build Coastguard Worker  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12*0d6140beSAndroid Build Coastguard Worker  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13*0d6140beSAndroid Build Coastguard Worker  * GNU General Public License for more details.
14*0d6140beSAndroid Build Coastguard Worker  */
15*0d6140beSAndroid Build Coastguard Worker 
16*0d6140beSAndroid Build Coastguard Worker #include "lifecycle.h"
17*0d6140beSAndroid Build Coastguard Worker 
probe_chip(const struct programmer_entry * prog,struct flashrom_programmer * flashprog,const char * const chip_name)18*0d6140beSAndroid Build Coastguard Worker static void probe_chip(const struct programmer_entry *prog,
19*0d6140beSAndroid Build Coastguard Worker 			struct flashrom_programmer *flashprog,
20*0d6140beSAndroid Build Coastguard Worker 			const char *const chip_name)
21*0d6140beSAndroid Build Coastguard Worker {
22*0d6140beSAndroid Build Coastguard Worker 	struct flashrom_flashctx *flashctx;
23*0d6140beSAndroid Build Coastguard Worker 
24*0d6140beSAndroid Build Coastguard Worker 	printf("Testing flashrom_flash_probe for programmer=%s, chip=%s ... \n", prog->name, chip_name);
25*0d6140beSAndroid Build Coastguard Worker 	assert_int_equal(0, flashrom_flash_probe(&flashctx, flashprog, chip_name));
26*0d6140beSAndroid Build Coastguard Worker 	printf("... flashrom_flash_probe for programmer=%s successful\n", prog->name);
27*0d6140beSAndroid Build Coastguard Worker 
28*0d6140beSAndroid Build Coastguard Worker 	flashrom_flash_release(flashctx); /* cleanup */
29*0d6140beSAndroid Build Coastguard Worker }
30*0d6140beSAndroid Build Coastguard Worker 
run_lifecycle(void ** state,const struct io_mock * io,const struct programmer_entry * prog,const char * param,const char * const chip_name,void (* action)(const struct programmer_entry * prog,struct flashrom_programmer * flashprog,const char * const chip_name))31*0d6140beSAndroid Build Coastguard Worker static void run_lifecycle(void **state, const struct io_mock *io, const struct programmer_entry *prog,
32*0d6140beSAndroid Build Coastguard Worker 				const char *param, const char *const chip_name,
33*0d6140beSAndroid Build Coastguard Worker 				void (*action)(const struct programmer_entry *prog,
34*0d6140beSAndroid Build Coastguard Worker 						struct flashrom_programmer *flashprog,
35*0d6140beSAndroid Build Coastguard Worker 						const char *const chip_name))
36*0d6140beSAndroid Build Coastguard Worker {
37*0d6140beSAndroid Build Coastguard Worker 	(void) state; /* unused */
38*0d6140beSAndroid Build Coastguard Worker 
39*0d6140beSAndroid Build Coastguard Worker 	io_mock_register(io);
40*0d6140beSAndroid Build Coastguard Worker 
41*0d6140beSAndroid Build Coastguard Worker 	struct flashrom_programmer *flashprog;
42*0d6140beSAndroid Build Coastguard Worker 
43*0d6140beSAndroid Build Coastguard Worker 	printf("Testing flashrom_programmer_init for programmer=%s ...\n", prog->name);
44*0d6140beSAndroid Build Coastguard Worker 	assert_int_equal(0, flashrom_programmer_init(&flashprog, prog->name, param));
45*0d6140beSAndroid Build Coastguard Worker 	printf("... flashrom_programmer_init for programmer=%s successful\n", prog->name);
46*0d6140beSAndroid Build Coastguard Worker 
47*0d6140beSAndroid Build Coastguard Worker 	if (action)
48*0d6140beSAndroid Build Coastguard Worker 		action(prog, flashprog, chip_name);
49*0d6140beSAndroid Build Coastguard Worker 
50*0d6140beSAndroid Build Coastguard Worker 	printf("Testing flashrom_programmer_shutdown for programmer=%s ...\n", prog->name);
51*0d6140beSAndroid Build Coastguard Worker 	assert_int_equal(0, flashrom_programmer_shutdown(flashprog));
52*0d6140beSAndroid Build Coastguard Worker 	printf("... flashrom_programmer_shutdown for programmer=%s successful\n", prog->name);
53*0d6140beSAndroid Build Coastguard Worker 
54*0d6140beSAndroid Build Coastguard Worker 	io_mock_register(NULL);
55*0d6140beSAndroid Build Coastguard Worker }
56*0d6140beSAndroid Build Coastguard Worker 
run_basic_lifecycle(void ** state,const struct io_mock * io,const struct programmer_entry * prog,const char * param)57*0d6140beSAndroid Build Coastguard Worker void run_basic_lifecycle(void **state, const struct io_mock *io,
58*0d6140beSAndroid Build Coastguard Worker 		const struct programmer_entry *prog, const char *param)
59*0d6140beSAndroid Build Coastguard Worker {
60*0d6140beSAndroid Build Coastguard Worker 	/* Basic lifecycle only does init and shutdown,
61*0d6140beSAndroid Build Coastguard Worker 	 * so neither chip name nor action is needed. */
62*0d6140beSAndroid Build Coastguard Worker 	run_lifecycle(state, io, prog, param, NULL /* chip_name */, NULL /* action */);
63*0d6140beSAndroid Build Coastguard Worker }
64*0d6140beSAndroid Build Coastguard Worker 
run_probe_lifecycle(void ** state,const struct io_mock * io,const struct programmer_entry * prog,const char * param,const char * const chip_name)65*0d6140beSAndroid Build Coastguard Worker void run_probe_lifecycle(void **state, const struct io_mock *io,
66*0d6140beSAndroid Build Coastguard Worker 		const struct programmer_entry *prog, const char *param, const char *const chip_name)
67*0d6140beSAndroid Build Coastguard Worker {
68*0d6140beSAndroid Build Coastguard Worker 	/* Each probe lifecycle should run independently, without cache. */
69*0d6140beSAndroid Build Coastguard Worker 	clear_spi_id_cache();
70*0d6140beSAndroid Build Coastguard Worker 	run_lifecycle(state, io, prog, param, chip_name, &probe_chip);
71*0d6140beSAndroid Build Coastguard Worker }
72*0d6140beSAndroid Build Coastguard Worker 
run_init_error_path(void ** state,const struct io_mock * io,const struct programmer_entry * prog,const char * param,const int error_code)73*0d6140beSAndroid Build Coastguard Worker void run_init_error_path(void **state, const struct io_mock *io, const struct programmer_entry *prog,
74*0d6140beSAndroid Build Coastguard Worker 				const char *param, const int error_code)
75*0d6140beSAndroid Build Coastguard Worker {
76*0d6140beSAndroid Build Coastguard Worker 	(void) state; /* unused */
77*0d6140beSAndroid Build Coastguard Worker 
78*0d6140beSAndroid Build Coastguard Worker 	io_mock_register(io);
79*0d6140beSAndroid Build Coastguard Worker 
80*0d6140beSAndroid Build Coastguard Worker 	struct flashrom_programmer *flashprog;
81*0d6140beSAndroid Build Coastguard Worker 
82*0d6140beSAndroid Build Coastguard Worker 	printf("Testing init error path for programmer=%s with params: %s ...\n", prog->name, param);
83*0d6140beSAndroid Build Coastguard Worker 	assert_int_equal(error_code, flashrom_programmer_init(&flashprog, prog->name, param));
84*0d6140beSAndroid Build Coastguard Worker 	printf("... init failed with error code %i as expected\n", error_code);
85*0d6140beSAndroid Build Coastguard Worker 
86*0d6140beSAndroid Build Coastguard Worker 	/*
87*0d6140beSAndroid Build Coastguard Worker 	 * `flashrom_programmer_shutdown` runs only registered shutdown functions, which means
88*0d6140beSAndroid Build Coastguard Worker 	 * if nothing has been registered then nothing runs.
89*0d6140beSAndroid Build Coastguard Worker 	 * Since this is testing error path on initialisation and error can happen at different
90*0d6140beSAndroid Build Coastguard Worker 	 * phases of init, we don't know whether shutdown function has already been registered
91*0d6140beSAndroid Build Coastguard Worker 	 * or not yet. Running `flashrom_programmer_shutdown` covers both situations.
92*0d6140beSAndroid Build Coastguard Worker 	 */
93*0d6140beSAndroid Build Coastguard Worker 	printf("Running programmer shutdown in case anything got registered...\n");
94*0d6140beSAndroid Build Coastguard Worker 	assert_int_equal(0, flashrom_programmer_shutdown(flashprog));
95*0d6140beSAndroid Build Coastguard Worker 	printf("... completed\n");
96*0d6140beSAndroid Build Coastguard Worker 
97*0d6140beSAndroid Build Coastguard Worker 	io_mock_register(NULL);
98*0d6140beSAndroid Build Coastguard Worker }
99