mirror of
				https://xff.cz/git/u-boot/
				synced 2025-10-26 16:13:55 +01:00 
			
		
		
		
	cmd: env: check real location for env info command
Check the current ENV location, dynamically provided by the weak function env_get_location to be sure that the environment can be persistent. The compilation flag ENV_IS_IN_DEVICE is not enough when the board dynamically select the available storage location (according boot device for example). This patch solves issue for stm32mp1 platform, when the boot device is USB. Signed-off-by: Patrick Delaunay <patrick.delaunay@st.com> Reviewed-by: Simon Glass <sjg@chromium.org> Reviewed-by: Tom Rini <trini@konsulko.com>
This commit is contained in:
		
				
					committed by
					
						 Tom Rini
						Tom Rini
					
				
			
			
				
	
			
			
			
						parent
						
							6718ebd032
						
					
				
				
					commit
					2f96b3238c
				
			
							
								
								
									
										15
									
								
								cmd/nvedit.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								cmd/nvedit.c
									
									
									
									
									
								
							| @@ -1233,6 +1233,9 @@ static int do_env_info(struct cmd_tbl *cmdtp, int flag, | ||||
| 	int eval_flags = 0; | ||||
| 	int eval_results = 0; | ||||
| 	bool quiet = false; | ||||
| #if defined(CONFIG_CMD_SAVEENV) && defined(ENV_IS_IN_DEVICE) | ||||
| 	enum env_location loc; | ||||
| #endif | ||||
|  | ||||
| 	/* display environment information */ | ||||
| 	if (argc <= 1) | ||||
| @@ -1274,9 +1277,15 @@ static int do_env_info(struct cmd_tbl *cmdtp, int flag, | ||||
| 	/* evaluate whether environment can be persisted */ | ||||
| 	if (eval_flags & ENV_INFO_IS_PERSISTED) { | ||||
| #if defined(CONFIG_CMD_SAVEENV) && defined(ENV_IS_IN_DEVICE) | ||||
| 		if (!quiet) | ||||
| 			printf("Environment can be persisted\n"); | ||||
| 		eval_results |= ENV_INFO_IS_PERSISTED; | ||||
| 		loc = env_get_location(ENVOP_SAVE, gd->env_load_prio); | ||||
| 		if (ENVL_NOWHERE != loc && ENVL_UNKNOWN != loc) { | ||||
| 			if (!quiet) | ||||
| 				printf("Environment can be persisted\n"); | ||||
| 			eval_results |= ENV_INFO_IS_PERSISTED; | ||||
| 		} else { | ||||
| 			if (!quiet) | ||||
| 				printf("Environment cannot be persisted\n"); | ||||
| 		} | ||||
| #else | ||||
| 		if (!quiet) | ||||
| 			printf("Environment cannot be persisted\n"); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user