mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 22:41:21 +02:00 
			
		
		
		
	Merge branch '2022-04-14-assorted-updates'
- Apple M1 Ultra support, TI power domain fix, atsha204a big endian support, LED cleanups and support for default-state, increase malloc pool on sandbox, ubifs bugfix, further serial cleanup / semihost support, fix a few cases around enabling/disabling FS support in SPL, clean up duplication of table_compute_checksum()
This commit is contained in:
		
						commit
						74ae732d80
					
				
							
								
								
									
										1
									
								
								Kconfig
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								Kconfig
									
									
									
									
									
								
							| @ -263,6 +263,7 @@ config SYS_MALLOC_F_LEN | |||||||
| 
 | 
 | ||||||
| config SYS_MALLOC_LEN | config SYS_MALLOC_LEN | ||||||
| 	hex "Define memory for Dynamic allocation" | 	hex "Define memory for Dynamic allocation" | ||||||
|  | 	default 0x4000000 if SANDBOX | ||||||
| 	default 0x2000000 if ARCH_ROCKCHIP || ARCH_OMAP2PLUS || ARCH_MESON | 	default 0x2000000 if ARCH_ROCKCHIP || ARCH_OMAP2PLUS || ARCH_MESON | ||||||
| 	default 0x200000 if ARCH_BMIPS || X86 | 	default 0x200000 if ARCH_BMIPS || X86 | ||||||
| 	default 0x120000 if MACH_SUNIV | 	default 0x120000 if MACH_SUNIV | ||||||
|  | |||||||
| @ -177,6 +177,171 @@ static struct mm_region t6000_mem_map[] = { | |||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | /* Apple M1 Ultra */ | ||||||
|  | 
 | ||||||
|  | static struct mm_region t6002_mem_map[] = { | ||||||
|  | 	{ | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x280000000, | ||||||
|  | 		.phys = 0x280000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x380000000, | ||||||
|  | 		.phys = 0x380000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x580000000, | ||||||
|  | 		.phys = 0x580000000, | ||||||
|  | 		.size = SZ_512M, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* PCIE */ | ||||||
|  | 		.virt = 0x5a0000000, | ||||||
|  | 		.phys = 0x5a0000000, | ||||||
|  | 		.size = SZ_512M, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRE) | | ||||||
|  | 			 PTE_BLOCK_INNER_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* PCIE */ | ||||||
|  | 		.virt = 0x5c0000000, | ||||||
|  | 		.phys = 0x5c0000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRE) | | ||||||
|  | 			 PTE_BLOCK_INNER_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x700000000, | ||||||
|  | 		.phys = 0x700000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0xb00000000, | ||||||
|  | 		.phys = 0xb00000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0xf00000000, | ||||||
|  | 		.phys = 0xf00000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x1300000000, | ||||||
|  | 		.phys = 0x1300000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x2280000000, | ||||||
|  | 		.phys = 0x2280000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x2380000000, | ||||||
|  | 		.phys = 0x2380000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x2580000000, | ||||||
|  | 		.phys = 0x2580000000, | ||||||
|  | 		.size = SZ_512M, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* PCIE */ | ||||||
|  | 		.virt = 0x25a0000000, | ||||||
|  | 		.phys = 0x25a0000000, | ||||||
|  | 		.size = SZ_512M, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRE) | | ||||||
|  | 			 PTE_BLOCK_INNER_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* PCIE */ | ||||||
|  | 		.virt = 0x25c0000000, | ||||||
|  | 		.phys = 0x25c0000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRE) | | ||||||
|  | 			 PTE_BLOCK_INNER_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x2700000000, | ||||||
|  | 		.phys = 0x2700000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x2b00000000, | ||||||
|  | 		.phys = 0x2b00000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x2f00000000, | ||||||
|  | 		.phys = 0x2f00000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* I/O */ | ||||||
|  | 		.virt = 0x3300000000, | ||||||
|  | 		.phys = 0x3300000000, | ||||||
|  | 		.size = SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | | ||||||
|  | 			 PTE_BLOCK_NON_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* RAM */ | ||||||
|  | 		.virt = 0x10000000000, | ||||||
|  | 		.phys = 0x10000000000, | ||||||
|  | 		.size = 16UL * SZ_1G, | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) | | ||||||
|  | 			 PTE_BLOCK_INNER_SHARE | ||||||
|  | 	}, { | ||||||
|  | 		/* Framebuffer */ | ||||||
|  | 		.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL_NC) | | ||||||
|  | 			 PTE_BLOCK_INNER_SHARE | | ||||||
|  | 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN | ||||||
|  | 	}, { | ||||||
|  | 		/* List terminator */ | ||||||
|  | 		0, | ||||||
|  | 	} | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| struct mm_region *mem_map; | struct mm_region *mem_map; | ||||||
| 
 | 
 | ||||||
| int board_init(void) | int board_init(void) | ||||||
| @ -216,6 +381,8 @@ void build_mem_map(void) | |||||||
| 		mem_map = t6000_mem_map; | 		mem_map = t6000_mem_map; | ||||||
| 	else if (of_machine_is_compatible("apple,t6001")) | 	else if (of_machine_is_compatible("apple,t6001")) | ||||||
| 		mem_map = t6000_mem_map; | 		mem_map = t6000_mem_map; | ||||||
|  | 	else if (of_machine_is_compatible("apple,t6002")) | ||||||
|  | 		mem_map = t6002_mem_map; | ||||||
| 	else | 	else | ||||||
| 		panic("Unsupported SoC\n"); | 		panic("Unsupported SoC\n"); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,6 +16,28 @@ struct sandbox_serial_plat { | |||||||
| 	int colour;	/* Text colour to use for output, -1 for none */ | 	int colour;	/* Text colour to use for output, -1 for none */ | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * sandbox_serial_written() - Get the total number of characters written | ||||||
|  |  * | ||||||
|  |  * This returns the number of characters written by the sandbox serial | ||||||
|  |  * device. It is intended for performing tests of the serial subsystem | ||||||
|  |  * where a console buffer cannot be used. The absolute number should not be | ||||||
|  |  * relied upon; call this function twice and compare the difference. | ||||||
|  |  * | ||||||
|  |  * Return: The number of characters written | ||||||
|  |  */ | ||||||
|  | size_t sandbox_serial_written(void); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * sandbox_serial_endisable() - Enable or disable serial output | ||||||
|  |  * @enabled: Whether serial output should be enabled or not | ||||||
|  |  * | ||||||
|  |  * This allows tests to enable or disable the sandbox serial output. All | ||||||
|  |  * processes relating to writing output (except the actual writing) will be | ||||||
|  |  * performed. | ||||||
|  |  */ | ||||||
|  | void sandbox_serial_endisable(bool enabled); | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * struct sandbox_serial_priv - Private data for this driver |  * struct sandbox_serial_priv - Private data for this driver | ||||||
|  * |  * | ||||||
|  | |||||||
| @ -16,19 +16,6 @@ | |||||||
| /* SeaBIOS expects coreboot tables at address range 0x0000-0x1000 */ | /* SeaBIOS expects coreboot tables at address range 0x0000-0x1000 */ | ||||||
| #define CB_TABLE_ADDR	0x800 | #define CB_TABLE_ADDR	0x800 | ||||||
| 
 | 
 | ||||||
| /**
 |  | ||||||
|  * table_compute_checksum() - Compute a table checksum |  | ||||||
|  * |  | ||||||
|  * This computes an 8-bit checksum for the configuration table. |  | ||||||
|  * All bytes in the configuration table, including checksum itself and |  | ||||||
|  * reserved bytes must add up to zero. |  | ||||||
|  * |  | ||||||
|  * @v:		configuration table base address |  | ||||||
|  * @len:	configuration table size |  | ||||||
|  * @return:	the 8-bit checksum |  | ||||||
|  */ |  | ||||||
| u8 table_compute_checksum(void *v, int len); |  | ||||||
| 
 |  | ||||||
| /**
 | /**
 | ||||||
|  * table_fill_string() - Fill a string with pad in the configuration table |  * table_fill_string() - Fill a string with pad in the configuration table | ||||||
|  * |  * | ||||||
|  | |||||||
| @ -511,6 +511,11 @@ int ubi_part(char *part_name, const char *vid_header_offset) | |||||||
| 	struct mtd_info *mtd; | 	struct mtd_info *mtd; | ||||||
| 	int err = 0; | 	int err = 0; | ||||||
| 
 | 
 | ||||||
|  | 	if (ubi && ubi->mtd && !strcmp(ubi->mtd->name, part_name)) { | ||||||
|  | 		printf("UBI partition '%s' already selected\n", part_name); | ||||||
|  | 		return 0; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	ubi_detach(); | 	ubi_detach(); | ||||||
| 
 | 
 | ||||||
| 	mtd_probe_devices(); | 	mtd_probe_devices(); | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| CONFIG_SYS_TEXT_BASE=0 | CONFIG_SYS_TEXT_BASE=0 | ||||||
| CONFIG_SYS_MALLOC_LEN=0x2000000 |  | ||||||
| CONFIG_NR_DRAM_BANKS=1 | CONFIG_NR_DRAM_BANKS=1 | ||||||
| CONFIG_ENV_SIZE=0x2000 | CONFIG_ENV_SIZE=0x2000 | ||||||
| CONFIG_DEFAULT_DEVICE_TREE="sandbox64" | CONFIG_DEFAULT_DEVICE_TREE="sandbox64" | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| CONFIG_SYS_TEXT_BASE=0 | CONFIG_SYS_TEXT_BASE=0 | ||||||
| CONFIG_SYS_MALLOC_LEN=0x2000000 |  | ||||||
| CONFIG_NR_DRAM_BANKS=1 | CONFIG_NR_DRAM_BANKS=1 | ||||||
| CONFIG_ENV_SIZE=0x2000 | CONFIG_ENV_SIZE=0x2000 | ||||||
| CONFIG_DEFAULT_DEVICE_TREE="sandbox" | CONFIG_DEFAULT_DEVICE_TREE="sandbox" | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| CONFIG_SYS_TEXT_BASE=0 | CONFIG_SYS_TEXT_BASE=0 | ||||||
| CONFIG_SYS_MALLOC_LEN=0x2000000 |  | ||||||
| CONFIG_NR_DRAM_BANKS=1 | CONFIG_NR_DRAM_BANKS=1 | ||||||
| CONFIG_ENV_SIZE=0x2000 | CONFIG_ENV_SIZE=0x2000 | ||||||
| CONFIG_DEFAULT_DEVICE_TREE="sandbox" | CONFIG_DEFAULT_DEVICE_TREE="sandbox" | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| CONFIG_SYS_TEXT_BASE=0x200000 | CONFIG_SYS_TEXT_BASE=0x200000 | ||||||
| CONFIG_SYS_MALLOC_LEN=0x2000000 |  | ||||||
| CONFIG_SPL_GPIO=y | CONFIG_SPL_GPIO=y | ||||||
| CONFIG_SPL_LIBCOMMON_SUPPORT=y | CONFIG_SPL_LIBCOMMON_SUPPORT=y | ||||||
| CONFIG_SPL_LIBGENERIC_SUPPORT=y | CONFIG_SPL_LIBGENERIC_SUPPORT=y | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| CONFIG_SYS_TEXT_BASE=0x200000 | CONFIG_SYS_TEXT_BASE=0x200000 | ||||||
| CONFIG_SYS_MALLOC_LEN=0x2000000 |  | ||||||
| CONFIG_SPL_GPIO=y | CONFIG_SPL_GPIO=y | ||||||
| CONFIG_SPL_LIBCOMMON_SUPPORT=y | CONFIG_SPL_LIBCOMMON_SUPPORT=y | ||||||
| CONFIG_SPL_LIBGENERIC_SUPPORT=y | CONFIG_SPL_LIBGENERIC_SUPPORT=y | ||||||
|  | |||||||
| @ -66,37 +66,56 @@ int led_set_period(struct udevice *dev, int period_ms) | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | /* This is superseded by led_post_bind()/led_post_probe() below. */ | ||||||
| int led_default_state(void) | int led_default_state(void) | ||||||
| { | { | ||||||
| 	struct udevice *dev; | 	return 0; | ||||||
| 	struct uclass *uc; | } | ||||||
|  | 
 | ||||||
|  | static int led_post_bind(struct udevice *dev) | ||||||
|  | { | ||||||
|  | 	struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev); | ||||||
| 	const char *default_state; | 	const char *default_state; | ||||||
| 	int ret; |  | ||||||
| 
 | 
 | ||||||
| 	ret = uclass_get(UCLASS_LED, &uc); | 	uc_plat->label = dev_read_string(dev, "label"); | ||||||
| 	if (ret) | 	if (!uc_plat->label) | ||||||
| 		return ret; | 		uc_plat->label = ofnode_get_name(dev_ofnode(dev)); | ||||||
| 	for (uclass_find_first_device(UCLASS_LED, &dev); |  | ||||||
| 	     dev; |  | ||||||
| 	     uclass_find_next_device(&dev)) { |  | ||||||
| 		default_state = dev_read_string(dev, "default-state"); |  | ||||||
| 		if (!default_state) |  | ||||||
| 			continue; |  | ||||||
| 		ret = device_probe(dev); |  | ||||||
| 		if (ret) |  | ||||||
| 			return ret; |  | ||||||
| 		if (!strncmp(default_state, "on", 2)) |  | ||||||
| 			led_set_state(dev, LEDST_ON); |  | ||||||
| 		else if (!strncmp(default_state, "off", 3)) |  | ||||||
| 			led_set_state(dev, LEDST_OFF); |  | ||||||
| 		/* default-state = "keep" : device is only probed */ |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	return ret; | 	uc_plat->default_state = LEDST_COUNT; | ||||||
|  | 
 | ||||||
|  | 	default_state = dev_read_string(dev, "default-state"); | ||||||
|  | 	if (!default_state) | ||||||
|  | 		return 0; | ||||||
|  | 
 | ||||||
|  | 	if (!strncmp(default_state, "on", 2)) | ||||||
|  | 		uc_plat->default_state = LEDST_ON; | ||||||
|  | 	else if (!strncmp(default_state, "off", 3)) | ||||||
|  | 		uc_plat->default_state = LEDST_OFF; | ||||||
|  | 	else | ||||||
|  | 		return 0; | ||||||
|  | 
 | ||||||
|  | 	/*
 | ||||||
|  | 	 * In case the LED has default-state DT property, trigger | ||||||
|  | 	 * probe() to configure its default state during startup. | ||||||
|  | 	 */ | ||||||
|  | 	return device_probe(dev); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int led_post_probe(struct udevice *dev) | ||||||
|  | { | ||||||
|  | 	struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev); | ||||||
|  | 
 | ||||||
|  | 	if (uc_plat->default_state == LEDST_ON || | ||||||
|  | 	    uc_plat->default_state == LEDST_OFF) | ||||||
|  | 		led_set_state(dev, uc_plat->default_state); | ||||||
|  | 
 | ||||||
|  | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| UCLASS_DRIVER(led) = { | UCLASS_DRIVER(led) = { | ||||||
| 	.id		= UCLASS_LED, | 	.id		= UCLASS_LED, | ||||||
| 	.name		= "led", | 	.name		= "led", | ||||||
| 	.per_device_plat_auto	= sizeof(struct led_uc_plat), | 	.per_device_plat_auto	= sizeof(struct led_uc_plat), | ||||||
|  | 	.post_bind	= led_post_bind, | ||||||
|  | 	.post_probe	= led_post_probe, | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -204,26 +204,14 @@ static int bcm6328_led_bind(struct udevice *parent) | |||||||
| 	ofnode node; | 	ofnode node; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		struct udevice *dev; | 		struct udevice *dev; | ||||||
| 		const char *label; |  | ||||||
| 		int ret; | 		int ret; | ||||||
| 
 | 
 | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) { |  | ||||||
| 			debug("%s: node %s has no label\n", __func__, |  | ||||||
| 			      ofnode_get_name(node)); |  | ||||||
| 			return -EINVAL; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		ret = device_bind_driver_to_node(parent, "bcm6328-led", | 		ret = device_bind_driver_to_node(parent, "bcm6328-led", | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 
 |  | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
|  | |||||||
| @ -174,26 +174,14 @@ static int bcm6358_led_bind(struct udevice *parent) | |||||||
| 	ofnode node; | 	ofnode node; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		struct udevice *dev; | 		struct udevice *dev; | ||||||
| 		const char *label; |  | ||||||
| 		int ret; | 		int ret; | ||||||
| 
 | 
 | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) { |  | ||||||
| 			debug("%s: node %s has no label\n", __func__, |  | ||||||
| 			      ofnode_get_name(node)); |  | ||||||
| 			return -EINVAL; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		ret = device_bind_driver_to_node(parent, "bcm6358-led", | 		ret = device_bind_driver_to_node(parent, "bcm6358-led", | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 
 |  | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
|  | |||||||
| @ -229,26 +229,14 @@ static int bcm6753_led_bind(struct udevice *parent) | |||||||
| 	ofnode node; | 	ofnode node; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		struct udevice *dev; | 		struct udevice *dev; | ||||||
| 		const char *label; |  | ||||||
| 		int ret; | 		int ret; | ||||||
| 
 | 
 | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) { |  | ||||||
| 			debug("%s: node %s has no label\n", __func__, |  | ||||||
| 			      ofnode_get_name(node)); |  | ||||||
| 			return -EINVAL; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		ret = device_bind_driver_to_node(parent, "bcm6753-led", | 		ret = device_bind_driver_to_node(parent, "bcm6753-led", | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 
 |  | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
|  | |||||||
| @ -241,26 +241,14 @@ static int bcm6858_led_bind(struct udevice *parent) | |||||||
| 	ofnode node; | 	ofnode node; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		struct udevice *dev; | 		struct udevice *dev; | ||||||
| 		const char *label; |  | ||||||
| 		int ret; | 		int ret; | ||||||
| 
 | 
 | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) { |  | ||||||
| 			debug("%s: node %s has no label\n", __func__, |  | ||||||
| 			      ofnode_get_name(node)); |  | ||||||
| 			return -EINVAL; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		ret = device_bind_driver_to_node(parent, "bcm6858-led", | 		ret = device_bind_driver_to_node(parent, "bcm6858-led", | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 
 |  | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
|  | |||||||
| @ -256,25 +256,14 @@ static int cortina_led_bind(struct udevice *parent) | |||||||
| 	ofnode node; | 	ofnode node; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		struct udevice *dev; | 		struct udevice *dev; | ||||||
| 		const char *label; |  | ||||||
| 		int ret; | 		int ret; | ||||||
| 
 | 
 | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) { |  | ||||||
| 			debug("%s: node %s has no label\n", __func__, |  | ||||||
| 			      ofnode_get_name(node)); |  | ||||||
| 			return -EINVAL; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		ret = device_bind_driver_to_node(parent, "ca-leds", | 		ret = device_bind_driver_to_node(parent, "ca-leds", | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
|  | |||||||
| @ -95,19 +95,11 @@ static int led_gpio_bind(struct udevice *parent) | |||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		const char *label; |  | ||||||
| 
 |  | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) |  | ||||||
| 			label = ofnode_get_name(node); |  | ||||||
| 		ret = device_bind_driver_to_node(parent, "gpio_led", | 		ret = device_bind_driver_to_node(parent, "gpio_led", | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
|  | |||||||
| @ -151,21 +151,11 @@ static int led_pwm_bind(struct udevice *parent) | |||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	dev_for_each_subnode(node, parent) { | 	dev_for_each_subnode(node, parent) { | ||||||
| 		struct led_uc_plat *uc_plat; |  | ||||||
| 		const char *label; |  | ||||||
| 
 |  | ||||||
| 		label = ofnode_read_string(node, "label"); |  | ||||||
| 		if (!label) |  | ||||||
| 			label = ofnode_get_name(node); |  | ||||||
| 
 |  | ||||||
| 		ret = device_bind_driver_to_node(parent, LEDS_PWM_DRIVER_NAME, | 		ret = device_bind_driver_to_node(parent, LEDS_PWM_DRIVER_NAME, | ||||||
| 						 ofnode_get_name(node), | 						 ofnode_get_name(node), | ||||||
| 						 node, &dev); | 						 node, &dev); | ||||||
| 		if (ret) | 		if (ret) | ||||||
| 			return ret; | 			return ret; | ||||||
| 
 |  | ||||||
| 		uc_plat = dev_get_uclass_plat(dev); |  | ||||||
| 		uc_plat->label = label; |  | ||||||
| 	} | 	} | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
|  | |||||||
| @ -146,7 +146,7 @@ static u16 atsha204a_crc16(const u8 *buffer, size_t len) | |||||||
| 	while (len--) | 	while (len--) | ||||||
| 		crc = crc16_byte(crc, *buffer++); | 		crc = crc16_byte(crc, *buffer++); | ||||||
| 
 | 
 | ||||||
| 	return cpu_to_le16(crc); | 	return crc; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int atsha204a_send(struct udevice *dev, const u8 *buf, u8 len) | static int atsha204a_send(struct udevice *dev, const u8 *buf, u8 len) | ||||||
|  | |||||||
| @ -15,9 +15,6 @@ | |||||||
| #include <dm.h> | #include <dm.h> | ||||||
| #include <misc.h> | #include <misc.h> | ||||||
| #include <tables_csum.h> | #include <tables_csum.h> | ||||||
| #ifdef CONFIG_GENERATE_ACPI_TABLE |  | ||||||
| #include <asm/tables.h> |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
| #if defined(CONFIG_GENERATE_ACPI_TABLE) && !defined(CONFIG_SANDBOX) | #if defined(CONFIG_GENERATE_ACPI_TABLE) && !defined(CONFIG_SANDBOX) | ||||||
| /*
 | /*
 | ||||||
|  | |||||||
| @ -16,7 +16,9 @@ | |||||||
| #include <linux/iopoll.h> | #include <linux/iopoll.h> | ||||||
| 
 | 
 | ||||||
| #define PSC_PTCMD		0x120 | #define PSC_PTCMD		0x120 | ||||||
|  | #define PSC_PTCMD_H		0x124 | ||||||
| #define PSC_PTSTAT		0x128 | #define PSC_PTSTAT		0x128 | ||||||
|  | #define PSC_PTSTAT_H		0x12C | ||||||
| #define PSC_PDSTAT		0x200 | #define PSC_PDSTAT		0x200 | ||||||
| #define PSC_PDCTL		0x300 | #define PSC_PDCTL		0x300 | ||||||
| #define PSC_MDSTAT		0x800 | #define PSC_MDSTAT		0x800 | ||||||
| @ -120,10 +122,17 @@ static int ti_power_domain_probe(struct udevice *dev) | |||||||
| static int ti_pd_wait(struct ti_pd *pd) | static int ti_pd_wait(struct ti_pd *pd) | ||||||
| { | { | ||||||
| 	u32 ptstat; | 	u32 ptstat; | ||||||
|  | 	u32 pdoffset = 0; | ||||||
|  | 	u32 ptstatreg = PSC_PTSTAT; | ||||||
| 	int ret; | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	ret = readl_poll_timeout(pd->psc->base + PSC_PTSTAT, ptstat, | 	if (pd->id > 31) { | ||||||
| 				 !(ptstat & BIT(pd->id)), PD_TIMEOUT); | 		pdoffset = 32; | ||||||
|  | 		ptstatreg = PSC_PTSTAT_H; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	ret = readl_poll_timeout(pd->psc->base + ptstatreg, ptstat, | ||||||
|  | 				 !(ptstat & BIT(pd->id - pdoffset)), PD_TIMEOUT); | ||||||
| 
 | 
 | ||||||
| 	if (ret) | 	if (ret) | ||||||
| 		printf("%s: psc%d, pd%d failed to transition.\n", __func__, | 		printf("%s: psc%d, pd%d failed to transition.\n", __func__, | ||||||
| @ -134,7 +143,15 @@ static int ti_pd_wait(struct ti_pd *pd) | |||||||
| 
 | 
 | ||||||
| static void ti_pd_transition(struct ti_pd *pd) | static void ti_pd_transition(struct ti_pd *pd) | ||||||
| { | { | ||||||
| 	psc_write(BIT(pd->id), pd->psc, PSC_PTCMD); | 	u32 pdoffset = 0; | ||||||
|  | 	u32 ptcmdreg = PSC_PTCMD; | ||||||
|  | 
 | ||||||
|  | 	if (pd->id > 31) { | ||||||
|  | 		pdoffset = 32; | ||||||
|  | 		ptcmdreg = PSC_PTCMD_H; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	psc_write(BIT(pd->id - pdoffset), pd->psc, ptcmdreg); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| u8 ti_pd_state(struct ti_pd *pd) | u8 ti_pd_state(struct ti_pd *pd) | ||||||
|  | |||||||
| @ -779,6 +779,7 @@ config S5P_SERIAL | |||||||
| config SANDBOX_SERIAL | config SANDBOX_SERIAL | ||||||
| 	bool "Sandbox UART support" | 	bool "Sandbox UART support" | ||||||
| 	depends on SANDBOX | 	depends on SANDBOX | ||||||
|  | 	imply SERIAL_PUTS | ||||||
| 	help | 	help | ||||||
| 	  Select this to enable a seral UART for sandbox. This is required to | 	  Select this to enable a seral UART for sandbox. This is required to | ||||||
| 	  operate correctly, otherwise you will see no serial output from | 	  operate correctly, otherwise you will see no serial output from | ||||||
| @ -833,6 +834,7 @@ config SH_SCIF_CLK_FREQ | |||||||
| config SEMIHOSTING_SERIAL | config SEMIHOSTING_SERIAL | ||||||
| 	bool "Semihosting UART support" | 	bool "Semihosting UART support" | ||||||
| 	depends on SEMIHOSTING && !SERIAL_RX_BUFFER | 	depends on SEMIHOSTING && !SERIAL_RX_BUFFER | ||||||
|  | 	imply SERIAL_PUTS | ||||||
| 	help | 	help | ||||||
| 	  Select this to enable a serial UART using semihosting. Special halt | 	  Select this to enable a serial UART using semihosting. Special halt | ||||||
| 	  instructions will be issued which an external debugger (such as a | 	  instructions will be issued which an external debugger (such as a | ||||||
|  | |||||||
| @ -23,6 +23,19 @@ | |||||||
| 
 | 
 | ||||||
| DECLARE_GLOBAL_DATA_PTR; | DECLARE_GLOBAL_DATA_PTR; | ||||||
| 
 | 
 | ||||||
|  | static size_t _sandbox_serial_written = 1; | ||||||
|  | static bool sandbox_serial_enabled = true; | ||||||
|  | 
 | ||||||
|  | size_t sandbox_serial_written(void) | ||||||
|  | { | ||||||
|  | 	return _sandbox_serial_written; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void sandbox_serial_endisable(bool enabled) | ||||||
|  | { | ||||||
|  | 	sandbox_serial_enabled = enabled; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * output_ansi_colour() - Output an ANSI colour code |  * output_ansi_colour() - Output an ANSI colour code | ||||||
|  * |  * | ||||||
| @ -67,7 +80,7 @@ static int sandbox_serial_remove(struct udevice *dev) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int sandbox_serial_putc(struct udevice *dev, const char ch) | static void sandbox_print_color(struct udevice *dev) | ||||||
| { | { | ||||||
| 	struct sandbox_serial_priv *priv = dev_get_priv(dev); | 	struct sandbox_serial_priv *priv = dev_get_priv(dev); | ||||||
| 	struct sandbox_serial_plat *plat = dev_get_plat(dev); | 	struct sandbox_serial_plat *plat = dev_get_plat(dev); | ||||||
| @ -78,14 +91,44 @@ static int sandbox_serial_putc(struct udevice *dev, const char ch) | |||||||
| 		priv->start_of_line = false; | 		priv->start_of_line = false; | ||||||
| 		output_ansi_colour(plat->colour); | 		output_ansi_colour(plat->colour); | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int sandbox_serial_putc(struct udevice *dev, const char ch) | ||||||
|  | { | ||||||
|  | 	struct sandbox_serial_priv *priv = dev_get_priv(dev); | ||||||
| 
 | 
 | ||||||
| 	os_write(1, &ch, 1); |  | ||||||
| 	if (ch == '\n') | 	if (ch == '\n') | ||||||
| 		priv->start_of_line = true; | 		priv->start_of_line = true; | ||||||
| 
 | 
 | ||||||
|  | 	if (sandbox_serial_enabled) { | ||||||
|  | 		sandbox_print_color(dev); | ||||||
|  | 		os_write(1, &ch, 1); | ||||||
|  | 	} | ||||||
|  | 	_sandbox_serial_written += 1; | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static ssize_t sandbox_serial_puts(struct udevice *dev, const char *s, | ||||||
|  | 				   size_t len) | ||||||
|  | { | ||||||
|  | 	struct sandbox_serial_priv *priv = dev_get_priv(dev); | ||||||
|  | 	ssize_t ret; | ||||||
|  | 
 | ||||||
|  | 	if (s[len - 1] == '\n') | ||||||
|  | 		priv->start_of_line = true; | ||||||
|  | 
 | ||||||
|  | 	if (sandbox_serial_enabled) { | ||||||
|  | 		sandbox_print_color(dev); | ||||||
|  | 		ret = os_write(1, s, len); | ||||||
|  | 		if (ret < 0) | ||||||
|  | 			return ret; | ||||||
|  | 	} else { | ||||||
|  | 		ret = len; | ||||||
|  | 	} | ||||||
|  | 	_sandbox_serial_written += ret; | ||||||
|  | 	return ret; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static int sandbox_serial_pending(struct udevice *dev, bool input) | static int sandbox_serial_pending(struct udevice *dev, bool input) | ||||||
| { | { | ||||||
| 	struct sandbox_serial_priv *priv = dev_get_priv(dev); | 	struct sandbox_serial_priv *priv = dev_get_priv(dev); | ||||||
| @ -212,6 +255,7 @@ static int sandbox_serial_of_to_plat(struct udevice *dev) | |||||||
| 
 | 
 | ||||||
| static const struct dm_serial_ops sandbox_serial_ops = { | static const struct dm_serial_ops sandbox_serial_ops = { | ||||||
| 	.putc = sandbox_serial_putc, | 	.putc = sandbox_serial_putc, | ||||||
|  | 	.puts = sandbox_serial_puts, | ||||||
| 	.pending = sandbox_serial_pending, | 	.pending = sandbox_serial_pending, | ||||||
| 	.getc = sandbox_serial_getc, | 	.getc = sandbox_serial_getc, | ||||||
| 	.getconfig = sandbox_serial_getconfig, | 	.getconfig = sandbox_serial_getconfig, | ||||||
|  | |||||||
| @ -198,6 +198,22 @@ static void _serial_putc(struct udevice *dev, char ch) | |||||||
| 	} while (err == -EAGAIN); | 	} while (err == -EAGAIN); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static int __serial_puts(struct udevice *dev, const char *str, size_t len) | ||||||
|  | { | ||||||
|  | 	struct dm_serial_ops *ops = serial_get_ops(dev); | ||||||
|  | 
 | ||||||
|  | 	do { | ||||||
|  | 		ssize_t written = ops->puts(dev, str, len); | ||||||
|  | 
 | ||||||
|  | 		if (written < 0) | ||||||
|  | 			return written; | ||||||
|  | 		str += written; | ||||||
|  | 		len -= written; | ||||||
|  | 	} while (len); | ||||||
|  | 
 | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static void _serial_puts(struct udevice *dev, const char *str) | static void _serial_puts(struct udevice *dev, const char *str) | ||||||
| { | { | ||||||
| 	struct dm_serial_ops *ops = serial_get_ops(dev); | 	struct dm_serial_ops *ops = serial_get_ops(dev); | ||||||
| @ -210,19 +226,15 @@ static void _serial_puts(struct udevice *dev, const char *str) | |||||||
| 
 | 
 | ||||||
| 	do { | 	do { | ||||||
| 		const char *newline = strchrnul(str, '\n'); | 		const char *newline = strchrnul(str, '\n'); | ||||||
| 		size_t len = newline - str + !!*newline; | 		size_t len = newline - str; | ||||||
| 
 | 
 | ||||||
| 		do { | 		if (__serial_puts(dev, str, len)) | ||||||
| 			ssize_t written = ops->puts(dev, str, len); | 			return; | ||||||
| 
 | 
 | ||||||
| 			if (written < 0) | 		if (*newline && __serial_puts(dev, "\r\n", 2)) | ||||||
| 				return; | 			return; | ||||||
| 			str += written; |  | ||||||
| 			len -= written; |  | ||||||
| 		} while (len); |  | ||||||
| 
 | 
 | ||||||
| 		if (*newline) | 		str += len + !!*newline; | ||||||
| 			_serial_putc(dev, '\r'); |  | ||||||
| 	} while (*str); | 	} while (*str); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,12 +5,14 @@ | |||||||
| 
 | 
 | ||||||
| #include <common.h> | #include <common.h> | ||||||
| #include <dm.h> | #include <dm.h> | ||||||
|  | #include <malloc.h> | ||||||
| #include <serial.h> | #include <serial.h> | ||||||
| #include <semihosting.h> | #include <semihosting.h> | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|  * struct smh_serial_priv - Semihosting serial private data |  * struct smh_serial_priv - Semihosting serial private data | ||||||
|  * @infd: stdin file descriptor (or error) |  * @infd: stdin file descriptor (or error) | ||||||
|  |  * @outfd: stdout file descriptor (or error) | ||||||
|  */ |  */ | ||||||
| struct smh_serial_priv { | struct smh_serial_priv { | ||||||
| 	int infd; | 	int infd; | ||||||
| @ -36,8 +38,36 @@ static int smh_serial_putc(struct udevice *dev, const char ch) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static ssize_t smh_serial_puts(struct udevice *dev, const char *s, size_t len) | ||||||
|  | { | ||||||
|  | 	int ret; | ||||||
|  | 	struct smh_serial_priv *priv = dev_get_priv(dev); | ||||||
|  | 	unsigned long written; | ||||||
|  | 
 | ||||||
|  | 	if (priv->outfd < 0) { | ||||||
|  | 		char *buf; | ||||||
|  | 
 | ||||||
|  | 		/* Try and avoid a copy if we can */ | ||||||
|  | 		if (!s[len + 1]) { | ||||||
|  | 			smh_puts(s); | ||||||
|  | 			return len; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		buf = strndup(s, len); | ||||||
|  | 		smh_puts(buf); | ||||||
|  | 		free(buf); | ||||||
|  | 		return len; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	ret = smh_write(priv->outfd, s, len, &written); | ||||||
|  | 	if (written) | ||||||
|  | 		return written; | ||||||
|  | 	return ret; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static const struct dm_serial_ops smh_serial_ops = { | static const struct dm_serial_ops smh_serial_ops = { | ||||||
| 	.putc = smh_serial_putc, | 	.putc = smh_serial_putc, | ||||||
|  | 	.puts = smh_serial_puts, | ||||||
| 	.getc = smh_serial_getc, | 	.getc = smh_serial_getc, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -53,6 +83,7 @@ static int smh_serial_probe(struct udevice *dev) | |||||||
| 	struct smh_serial_priv *priv = dev_get_priv(dev); | 	struct smh_serial_priv *priv = dev_get_priv(dev); | ||||||
| 
 | 
 | ||||||
| 	priv->infd = smh_open(":tt", MODE_READ); | 	priv->infd = smh_open(":tt", MODE_READ); | ||||||
|  | 	priv->outfd = smh_open(":tt", MODE_WRITE); | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								fs/fs.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								fs/fs.c
									
									
									
									
									
								
							| @ -177,7 +177,7 @@ struct fstype_info { | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static struct fstype_info fstypes[] = { | static struct fstype_info fstypes[] = { | ||||||
| #ifdef CONFIG_FS_FAT | #if CONFIG_IS_ENABLED(FS_FAT) | ||||||
| 	{ | 	{ | ||||||
| 		.fstype = FS_TYPE_FAT, | 		.fstype = FS_TYPE_FAT, | ||||||
| 		.name = "fat", | 		.name = "fat", | ||||||
| @ -267,6 +267,7 @@ static struct fstype_info fstypes[] = { | |||||||
| 		.ln = fs_ln_unsupported, | 		.ln = fs_ln_unsupported, | ||||||
| 	}, | 	}, | ||||||
| #endif | #endif | ||||||
|  | #ifndef CONFIG_SPL_BUILD | ||||||
| #ifdef CONFIG_CMD_UBIFS | #ifdef CONFIG_CMD_UBIFS | ||||||
| 	{ | 	{ | ||||||
| 		.fstype = FS_TYPE_UBIFS, | 		.fstype = FS_TYPE_UBIFS, | ||||||
| @ -286,6 +287,7 @@ static struct fstype_info fstypes[] = { | |||||||
| 		.ln = fs_ln_unsupported, | 		.ln = fs_ln_unsupported, | ||||||
| 	}, | 	}, | ||||||
| #endif | #endif | ||||||
|  | #endif | ||||||
| #ifdef CONFIG_FS_BTRFS | #ifdef CONFIG_FS_BTRFS | ||||||
| 	{ | 	{ | ||||||
| 		.fstype = FS_TYPE_BTRFS, | 		.fstype = FS_TYPE_BTRFS, | ||||||
|  | |||||||
| @ -9,24 +9,6 @@ | |||||||
| 
 | 
 | ||||||
| struct udevice; | struct udevice; | ||||||
| 
 | 
 | ||||||
| /**
 |  | ||||||
|  * struct led_uc_plat - Platform data the uclass stores about each device |  | ||||||
|  * |  | ||||||
|  * @label:	LED label |  | ||||||
|  */ |  | ||||||
| struct led_uc_plat { |  | ||||||
| 	const char *label; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| /**
 |  | ||||||
|  * struct led_uc_priv - Private data the uclass stores about each device |  | ||||||
|  * |  | ||||||
|  * @period_ms:	Flash period in milliseconds |  | ||||||
|  */ |  | ||||||
| struct led_uc_priv { |  | ||||||
| 	int period_ms; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| enum led_state_t { | enum led_state_t { | ||||||
| 	LEDST_OFF = 0, | 	LEDST_OFF = 0, | ||||||
| 	LEDST_ON = 1, | 	LEDST_ON = 1, | ||||||
| @ -38,6 +20,26 @@ enum led_state_t { | |||||||
| 	LEDST_COUNT, | 	LEDST_COUNT, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * struct led_uc_plat - Platform data the uclass stores about each device | ||||||
|  |  * | ||||||
|  |  * @label:	LED label | ||||||
|  |  * @default_state:	LED default state | ||||||
|  |  */ | ||||||
|  | struct led_uc_plat { | ||||||
|  | 	const char *label; | ||||||
|  | 	enum led_state_t default_state; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * struct led_uc_priv - Private data the uclass stores about each device | ||||||
|  |  * | ||||||
|  |  * @period_ms:	Flash period in milliseconds | ||||||
|  |  */ | ||||||
|  | struct led_uc_priv { | ||||||
|  | 	int period_ms; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| struct led_ops { | struct led_ops { | ||||||
| 	/**
 | 	/**
 | ||||||
| 	 * set_state() - set the state of an LED | 	 * set_state() - set the state of an LED | ||||||
|  | |||||||
| @ -6,16 +6,17 @@ | |||||||
| #ifndef _TABLES_CSUM_H_ | #ifndef _TABLES_CSUM_H_ | ||||||
| #define _TABLES_CSUM_H_ | #define _TABLES_CSUM_H_ | ||||||
| 
 | 
 | ||||||
| static inline u8 table_compute_checksum(void *v, int len) | /**
 | ||||||
| { |  * table_compute_checksum() - Compute a table checksum | ||||||
| 	u8 *bytes = v; |  * | ||||||
| 	u8 checksum = 0; |  * This computes an 8-bit checksum for the configuration table. | ||||||
| 	int i; |  * All bytes in the configuration table, including checksum itself and | ||||||
| 
 |  * reserved bytes must add up to zero. | ||||||
| 	for (i = 0; i < len; i++) |  * | ||||||
| 		checksum -= bytes[i]; |  * @v:		configuration table base address | ||||||
| 
 |  * @len:	configuration table size | ||||||
| 	return checksum; |  * @return:	the 8-bit checksum | ||||||
| } |  */ | ||||||
|  | u8 table_compute_checksum(void *v, int len); | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ static int dm_test_cmd_pinmux_status_pinname(struct unit_test_state *uts) | |||||||
| 	/* Test that 'pinmux status <pinname>' displays the selected pin. */ | 	/* Test that 'pinmux status <pinname>' displays the selected pin. */ | ||||||
| 	console_record_reset(); | 	console_record_reset(); | ||||||
| 	run_command("pinmux status a5", 0); | 	run_command("pinmux status a5", 0); | ||||||
| 	ut_assert_nextlinen("a5        : gpio input ."); | 	ut_assert_nextlinen("a5        : gpio output ."); | ||||||
| 	ut_assert_console_end(); | 	ut_assert_console_end(); | ||||||
| 
 | 
 | ||||||
| 	console_record_reset(); | 	console_record_reset(); | ||||||
|  | |||||||
| @ -7,14 +7,22 @@ | |||||||
| #include <log.h> | #include <log.h> | ||||||
| #include <serial.h> | #include <serial.h> | ||||||
| #include <dm.h> | #include <dm.h> | ||||||
|  | #include <asm/serial.h> | ||||||
| #include <dm/test.h> | #include <dm/test.h> | ||||||
| #include <test/test.h> | #include <test/test.h> | ||||||
| #include <test/ut.h> | #include <test/ut.h> | ||||||
| 
 | 
 | ||||||
|  | static const char test_message[] = | ||||||
|  | 	"This is a test message\n" | ||||||
|  | 	"consisting of multiple lines\n"; | ||||||
|  | 
 | ||||||
| static int dm_test_serial(struct unit_test_state *uts) | static int dm_test_serial(struct unit_test_state *uts) | ||||||
| { | { | ||||||
|  | 	int i; | ||||||
| 	struct serial_device_info info_serial = {0}; | 	struct serial_device_info info_serial = {0}; | ||||||
| 	struct udevice *dev_serial; | 	struct udevice *dev_serial; | ||||||
|  | 	size_t start, putc_written; | ||||||
|  | 
 | ||||||
| 	uint value_serial; | 	uint value_serial; | ||||||
| 
 | 
 | ||||||
| 	ut_assertok(uclass_get_device_by_name(UCLASS_SERIAL, "serial", | 	ut_assertok(uclass_get_device_by_name(UCLASS_SERIAL, "serial", | ||||||
| @ -66,6 +74,17 @@ static int dm_test_serial(struct unit_test_state *uts) | |||||||
| 						   SERIAL_8_BITS, | 						   SERIAL_8_BITS, | ||||||
| 						   SERIAL_TWO_STOP))); | 						   SERIAL_TWO_STOP))); | ||||||
| 
 | 
 | ||||||
|  | 	/* Verify that putc and puts print the same number of characters */ | ||||||
|  | 	sandbox_serial_endisable(false); | ||||||
|  | 	start = sandbox_serial_written(); | ||||||
|  | 	for (i = 0; i < sizeof(test_message) - 1; i++) | ||||||
|  | 		serial_putc(test_message[i]); | ||||||
|  | 	putc_written = sandbox_serial_written(); | ||||||
|  | 	serial_puts(test_message); | ||||||
|  | 	sandbox_serial_endisable(true); | ||||||
|  | 	ut_asserteq(putc_written - start, | ||||||
|  | 		    sandbox_serial_written() - putc_written); | ||||||
|  | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user