MLK-16753-1 imx8m: add optee node according to runtime status
If TEE is enabled according to rom_pointer[0,1] passed to BL33 from ATF, uboot need to add the optee node in dts to let Kernel could probe the TEE driver. Signed-off-by: Peng Fan <peng.fan@nxp.com>
This commit is contained in:
		
							parent
							
								
									edd2be5f4b
								
							
						
					
					
						commit
						4341d35cc9
					
				| 
						 | 
					@ -189,6 +189,54 @@ bool is_usb_boot(void)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CONFIG_OF_SYSTEM_SETUP
 | 
					#ifdef CONFIG_OF_SYSTEM_SETUP
 | 
				
			||||||
 | 
					static int ft_add_optee_node(void *fdt, bd_t *bd)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						const char *path, *subpath;
 | 
				
			||||||
 | 
						int offs;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*
 | 
				
			||||||
 | 
						 * No TEE space allocated indicating no TEE running, so no
 | 
				
			||||||
 | 
						 * need to add optee node in dts
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						if (!rom_pointer[1])
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						offs = fdt_increase_size(fdt, 512);
 | 
				
			||||||
 | 
						if (offs) {
 | 
				
			||||||
 | 
							printf("No Space for dtb\n");
 | 
				
			||||||
 | 
							return 1;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						path = "/firmware";
 | 
				
			||||||
 | 
						offs = fdt_path_offset(fdt, path);
 | 
				
			||||||
 | 
						if (offs < 0) {
 | 
				
			||||||
 | 
							path = "/";
 | 
				
			||||||
 | 
							offs = fdt_path_offset(fdt, path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (offs < 0) {
 | 
				
			||||||
 | 
								printf("Could not find root node.\n");
 | 
				
			||||||
 | 
								return 1;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							subpath = "firmware";
 | 
				
			||||||
 | 
							offs = fdt_add_subnode(fdt, offs, subpath);
 | 
				
			||||||
 | 
							if (offs < 0) {
 | 
				
			||||||
 | 
								printf("Could not create %s node.\n", subpath);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						subpath = "optee";
 | 
				
			||||||
 | 
						offs = fdt_add_subnode(fdt, offs, subpath);
 | 
				
			||||||
 | 
						if (offs < 0) {
 | 
				
			||||||
 | 
							printf("Could not create %s node.\n", subpath);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						fdt_setprop_string(fdt, offs, "compatible", "linaro,optee-tz");
 | 
				
			||||||
 | 
						fdt_setprop_string(fdt, offs, "method", "smc");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int ft_system_setup(void *blob, bd_t *bd)
 | 
					int ft_system_setup(void *blob, bd_t *bd)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int i = 0;
 | 
						int i = 0;
 | 
				
			||||||
| 
						 | 
					@ -283,7 +331,7 @@ usb_modify_speed:
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return 0;
 | 
						return ft_add_optee_node(blob, bd);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue