mirror of
				https://review.coreboot.org/flashrom.git
				synced 2025-10-25 03:20:41 +02:00 
			
		
		
		
	Fix linking with libpayload
o Move flashbuses_to_text() to flashrom.c, it's not a cli function.
o Guard `!defined(HAVE_STRNLEN)`. This guard was introduced in
  23e10b87 (Add a bunch of new/tested stuff and various small
  changes 24) to support older BSDs. It's probably completely
  broken because HAVE_STRNLEN is presumably a GNU autotools
  thing. But we can't fix it without retesting these older BSDs.
Change-Id: I561135209b819361d125eeaeef9ff886d6bae987
Signed-off-by: Nico Huber <nico.huber@secunet.com>
Reviewed-on: https://review.coreboot.org/18738
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Reviewed-by: David Hendricks <david.hendricks@gmail.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
			
			
This commit is contained in:
		
							
								
								
									
										34
									
								
								cli_common.c
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								cli_common.c
									
									
									
									
									
								
							| @@ -24,40 +24,6 @@ | ||||
| #include <string.h> | ||||
| #include "flash.h" | ||||
|  | ||||
| /* | ||||
|  * Return a string corresponding to the bustype parameter. | ||||
|  * Memory is obtained with malloc() and must be freed with free() by the caller. | ||||
|  */ | ||||
| char *flashbuses_to_text(enum chipbustype bustype) | ||||
| { | ||||
| 	char *ret = calloc(1, 1); | ||||
| 	/* | ||||
| 	 * FIXME: Once all chipsets and flash chips have been updated, NONSPI | ||||
| 	 * will cease to exist and should be eliminated here as well. | ||||
| 	 */ | ||||
| 	if (bustype == BUS_NONSPI) { | ||||
| 		ret = strcat_realloc(ret, "Non-SPI, "); | ||||
| 	} else { | ||||
| 		if (bustype & BUS_PARALLEL) | ||||
| 			ret = strcat_realloc(ret, "Parallel, "); | ||||
| 		if (bustype & BUS_LPC) | ||||
| 			ret = strcat_realloc(ret, "LPC, "); | ||||
| 		if (bustype & BUS_FWH) | ||||
| 			ret = strcat_realloc(ret, "FWH, "); | ||||
| 		if (bustype & BUS_SPI) | ||||
| 			ret = strcat_realloc(ret, "SPI, "); | ||||
| 		if (bustype & BUS_PROG) | ||||
| 			ret = strcat_realloc(ret, "Programmer-specific, "); | ||||
| 		if (bustype == BUS_NONE) | ||||
| 			ret = strcat_realloc(ret, "None, "); | ||||
| 	} | ||||
| 	/* Kill last comma. */ | ||||
| 	ret[strlen(ret) - 2] = '\0'; | ||||
| 	ret = realloc(ret, strlen(ret) + 1); | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
|  | ||||
| void print_chip_support_status(const struct flashchip *chip) | ||||
| { | ||||
| 	if (chip->feature_bits & FEATURE_OTP) { | ||||
|   | ||||
							
								
								
									
										4
									
								
								flash.h
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								flash.h
									
									
									
									
									
								
							| @@ -264,13 +264,14 @@ void tolower_string(char *str); | ||||
| #ifdef __MINGW32__ | ||||
| char* strtok_r(char *str, const char *delim, char **nextp); | ||||
| #endif | ||||
| #if defined(__DJGPP__) || !defined(HAVE_STRNLEN) | ||||
| #if defined(__DJGPP__) || (!defined(__LIBPAYLOAD__) && !defined(HAVE_STRNLEN)) | ||||
| size_t strnlen(const char *str, size_t n); | ||||
| #endif | ||||
|  | ||||
| /* flashrom.c */ | ||||
| extern const char flashrom_version[]; | ||||
| extern const char *chip_to_probe; | ||||
| char *flashbuses_to_text(enum chipbustype bustype); | ||||
| int map_flash(struct flashctx *flash); | ||||
| void unmap_flash(struct flashctx *flash); | ||||
| int read_memmapped(struct flashctx *flash, uint8_t *buf, unsigned int start, unsigned int len); | ||||
| @@ -308,7 +309,6 @@ int do_verify(struct flashctx *, const char *const filename); | ||||
| #define ERROR_FLASHROM_LIMIT -201 | ||||
|  | ||||
| /* cli_common.c */ | ||||
| char *flashbuses_to_text(enum chipbustype bustype); | ||||
| void print_chip_support_status(const struct flashchip *chip); | ||||
|  | ||||
| /* cli_output.c */ | ||||
|   | ||||
							
								
								
									
										33
									
								
								flashrom.c
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								flashrom.c
									
									
									
									
									
								
							| @@ -1163,6 +1163,39 @@ int map_flash(struct flashctx *flash) | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Return a string corresponding to the bustype parameter. | ||||
|  * Memory is obtained with malloc() and must be freed with free() by the caller. | ||||
|  */ | ||||
| char *flashbuses_to_text(enum chipbustype bustype) | ||||
| { | ||||
| 	char *ret = calloc(1, 1); | ||||
| 	/* | ||||
| 	 * FIXME: Once all chipsets and flash chips have been updated, NONSPI | ||||
| 	 * will cease to exist and should be eliminated here as well. | ||||
| 	 */ | ||||
| 	if (bustype == BUS_NONSPI) { | ||||
| 		ret = strcat_realloc(ret, "Non-SPI, "); | ||||
| 	} else { | ||||
| 		if (bustype & BUS_PARALLEL) | ||||
| 			ret = strcat_realloc(ret, "Parallel, "); | ||||
| 		if (bustype & BUS_LPC) | ||||
| 			ret = strcat_realloc(ret, "LPC, "); | ||||
| 		if (bustype & BUS_FWH) | ||||
| 			ret = strcat_realloc(ret, "FWH, "); | ||||
| 		if (bustype & BUS_SPI) | ||||
| 			ret = strcat_realloc(ret, "SPI, "); | ||||
| 		if (bustype & BUS_PROG) | ||||
| 			ret = strcat_realloc(ret, "Programmer-specific, "); | ||||
| 		if (bustype == BUS_NONE) | ||||
| 			ret = strcat_realloc(ret, "None, "); | ||||
| 	} | ||||
| 	/* Kill last comma. */ | ||||
| 	ret[strlen(ret) - 2] = '\0'; | ||||
| 	ret = realloc(ret, strlen(ret) + 1); | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
| int probe_flash(struct registered_master *mst, int startchip, struct flashctx *flash, int force) | ||||
| { | ||||
| 	const struct flashchip *chip; | ||||
|   | ||||
| @@ -92,7 +92,7 @@ char* strtok_r(char *str, const char *delim, char **nextp) | ||||
| #endif | ||||
|  | ||||
| /* There is no strnlen in DJGPP */ | ||||
| #if defined(__DJGPP__) || !defined(HAVE_STRNLEN) | ||||
| #if defined(__DJGPP__) || (!defined(__LIBPAYLOAD__) && !defined(HAVE_STRNLEN)) | ||||
| size_t strnlen(const char *str, size_t n) | ||||
| { | ||||
| 	size_t i; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Nico Huber
					Nico Huber