mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 17:48:26 +00:00 
			
		
		
		
	The api_public.h header file undefined macro CONFIG_SYS_64BIT_LBA.
But api/api_storage.c includes this header before including part.h,
causing the type of lbaint_t and subsequently the type signature of
blk_dread() and blk_dwrite() functions to change from the rest of U-Boot
(if CONFIG_SYS_64BIT_LBA is defined for the board).
This is of course wrong, because the call to blk_dread() / blk_dwrite()
will receive mangled arguments.
Fix this by removing the undef of macro CONFIG_SYS_64BIT_LBA and instead
make the immediate code do what it would do as if the macro was not
defined.
Add a FIXME to whoever is maintaining this code.
CI managed to trigger this bug when compiling for lsxhl_defconfig, which
has CONFIG_API selected. The compiler complained about blk_dwrite() and
blk_dread() not matching original declarations:
  include/blk.h:280:15: warning: type of ‘blk_dwrite’ does not match
                                 original declaration
				 [-Wlto-type-mismatch]
  280 | unsigned long blk_dwrite(struct blk_desc *block_dev, lbaint_t st
      |               ^
  drivers/block/blk-uclass.c:456:15: note: type mismatch in parameter 2
  456 | unsigned long blk_dwrite(struct blk_desc *block_dev, lbaint_t st
      |               ^
Signed-off-by: Marek Behún <marek.behun@nic.cz>
Reviewed-by: Simon Glass <sjg@chromium.org>
		
	
			
		
			
				
	
	
		
			141 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ OR BSD-2-Clause */
 | |
| /*
 | |
|  * (C) Copyright 2007-2008 Semihalf
 | |
|  *
 | |
|  * Written by: Rafal Jaworowski <raj@semihalf.com>
 | |
|  */
 | |
| 
 | |
| #ifndef _API_PUBLIC_H_
 | |
| #define _API_PUBLIC_H_
 | |
| 
 | |
| #define API_EINVAL		1	/* invalid argument(s)	*/
 | |
| #define API_ENODEV		2	/* no device		*/
 | |
| #define API_ENOMEM		3	/* no memory		*/
 | |
| #define API_EBUSY		4	/* busy, occupied etc.	*/
 | |
| #define API_EIO			5	/* I/O error		*/
 | |
| #define API_ESYSC		6	/* syscall error	*/
 | |
| 
 | |
| typedef	int (*scp_t)(int, int *, ...);
 | |
| 
 | |
| #define API_SIG_VERSION	1
 | |
| #define API_SIG_MAGIC	"UBootAPI"
 | |
| #define API_SIG_MAGLEN	8
 | |
| 
 | |
| struct api_signature {
 | |
| 	char		magic[API_SIG_MAGLEN];	/* magic string */
 | |
| 	uint16_t	version;		/* API version */
 | |
| 	uint32_t	checksum;		/* checksum of this sig struct */
 | |
| 	scp_t		syscall;		/* entry point to the API */
 | |
| };
 | |
| 
 | |
| enum {
 | |
| 	API_RSVD = 0,
 | |
| 	API_GETC,
 | |
| 	API_PUTC,
 | |
| 	API_TSTC,
 | |
| 	API_PUTS,
 | |
| 	API_RESET,
 | |
| 	API_GET_SYS_INFO,
 | |
| 	API_UDELAY,
 | |
| 	API_GET_TIMER,
 | |
| 	API_DEV_ENUM,
 | |
| 	API_DEV_OPEN,
 | |
| 	API_DEV_CLOSE,
 | |
| 	API_DEV_READ,
 | |
| 	API_DEV_WRITE,
 | |
| 	API_ENV_ENUM,
 | |
| 	API_ENV_GET,
 | |
| 	API_ENV_SET,
 | |
| 	API_DISPLAY_GET_INFO,
 | |
| 	API_DISPLAY_DRAW_BITMAP,
 | |
| 	API_DISPLAY_CLEAR,
 | |
| 	API_MAXCALL
 | |
| };
 | |
| 
 | |
| #define MR_ATTR_FLASH	0x0001
 | |
| #define MR_ATTR_DRAM	0x0002
 | |
| #define MR_ATTR_SRAM	0x0003
 | |
| 
 | |
| struct mem_region {
 | |
| 	unsigned long	start;
 | |
| 	unsigned long	size;
 | |
| 	int		flags;
 | |
| };
 | |
| 
 | |
| struct sys_info {
 | |
| 	unsigned long		clk_bus;
 | |
| 	unsigned long		clk_cpu;
 | |
| 	unsigned long		bar;
 | |
| 	struct mem_region	*mr;
 | |
| 	int			mr_no;	/* number of memory regions */
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * FIXME: Previously this code was:
 | |
|  *
 | |
|  *   #undef CONFIG_SYS_64BIT_LBA
 | |
|  *   #ifdef CONFIG_SYS_64BIT_LBA
 | |
|  *   typedef u_int64_t lbasize_t;
 | |
|  *   #else
 | |
|  *   typedef unsigned long lbasize_t;
 | |
|  *   #endif
 | |
|  *
 | |
|  * But we cannot just undefine CONFIG_SYS_64BIT_LBA, because then in
 | |
|  * api/api_storage.c the type signature of lbaint_t will be different if
 | |
|  * CONFIG_SYS_64BIT_LBA is enabled for the board, which can result in various
 | |
|  * bugs.
 | |
|  * So simply define lbasize_t as an unsigned long, since this was what was done
 | |
|  * anyway for at least 13 years, but don't undefine CONFIG_SYS_64BIT_LBA.
 | |
|  */
 | |
| typedef unsigned long lbasize_t;
 | |
| 
 | |
| typedef unsigned long lbastart_t;
 | |
| 
 | |
| #define DEV_TYP_NONE	0x0000
 | |
| #define DEV_TYP_NET	0x0001
 | |
| 
 | |
| #define DEV_TYP_STOR	0x0002
 | |
| #define DT_STOR_IDE	0x0010
 | |
| #define DT_STOR_SCSI	0x0020
 | |
| #define DT_STOR_USB	0x0040
 | |
| #define DT_STOR_MMC	0x0080
 | |
| #define DT_STOR_SATA	0x0100
 | |
| 
 | |
| #define DEV_STA_CLOSED	0x0000		/* invalid, closed */
 | |
| #define DEV_STA_OPEN	0x0001		/* open i.e. active */
 | |
| 
 | |
| struct device_info {
 | |
| 	int	type;
 | |
| 	void	*cookie;
 | |
| 
 | |
| 	union {
 | |
| 		struct {
 | |
| 			lbasize_t	block_count;	/* no of blocks */
 | |
| 			unsigned long	block_size;	/* size of one block */
 | |
| 		} storage;
 | |
| 
 | |
| 		struct {
 | |
| 			unsigned char	hwaddr[6];
 | |
| 		} net;
 | |
| 	} info;
 | |
| #define di_stor info.storage
 | |
| #define di_net info.net
 | |
| 
 | |
| 	int	state;
 | |
| };
 | |
| 
 | |
| #define DISPLAY_TYPE_LCD	0x0001
 | |
| #define DISPLAY_TYPE_VIDEO	0x0002
 | |
| 
 | |
| struct display_info {
 | |
| 	int type;
 | |
| 	/* screen size in pixels */
 | |
| 	int pixel_width;
 | |
| 	int pixel_height;
 | |
| 	/* screen size in rows and columns of text */
 | |
| 	int screen_rows;
 | |
| 	int screen_cols;
 | |
| };
 | |
| 
 | |
| #endif /* _API_PUBLIC_H_ */
 |