mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-31 00:11:51 +01:00 
			
		
		
		
	On certain places it is required to flush output print buffers to ensure that text strings were sent to console or serial devices. For example when printing message that U-Boot is going to boot kernel or when U-Boot is going to change baudrate of terminal device. Therefore introduce a new flush() and fflush() functions into console code. These functions will call .flush callback of associated stdio_dev device. As this function may increase U-Boot side, allow to compile U-Boot without this function. For this purpose there is a new config CONSOLE_FLUSH_SUPPORT which is enabled by default and can be disabled. It is a good idea to have this option enabled for all boards which have enough space for it. When option is disabled when U-Boot defines just empty static inline function fflush() to avoid ifdefs in other code. Signed-off-by: Pali Rohár <pali@kernel.org> Reviewed-by: Simon Glass <sjg@chromium.org>
		
			
				
	
	
		
			119 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * (C) Copyright 2000
 | |
|  * Paolo Scaffardi, AIRVENT SAM s.p.a - RIMINI(ITALY), arsenio@tin.it
 | |
|  */
 | |
| 
 | |
| #ifndef _STDIO_DEV_H_
 | |
| #define _STDIO_DEV_H_
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <linux/list.h>
 | |
| 
 | |
| /*
 | |
|  * STDIO DEVICES
 | |
|  */
 | |
| 
 | |
| #define DEV_FLAGS_INPUT	 0x00000001	/* Device can be used as input	console */
 | |
| #define DEV_FLAGS_OUTPUT 0x00000002	/* Device can be used as output console */
 | |
| #define DEV_FLAGS_DM     0x00000004	/* Device priv is a struct udevice * */
 | |
| 
 | |
| int stdio_file_to_flags(const int file);
 | |
| 
 | |
| /* Device information */
 | |
| struct stdio_dev {
 | |
| 	int	flags;			/* Device flags: input/output/system	*/
 | |
| 	int	ext;			/* Supported extensions			*/
 | |
| 	char	name[32];		/* Device name				*/
 | |
| 
 | |
| /* GENERAL functions */
 | |
| 
 | |
| 	int (*start)(struct stdio_dev *dev);	/* To start the device */
 | |
| 	int (*stop)(struct stdio_dev *dev);	/* To stop the device */
 | |
| 
 | |
| /* OUTPUT functions */
 | |
| 
 | |
| 	/* To put a char */
 | |
| 	void (*putc)(struct stdio_dev *dev, const char c);
 | |
| 	/* To put a string (accelerator) */
 | |
| 	void (*puts)(struct stdio_dev *dev, const char *s);
 | |
| #ifdef CONFIG_CONSOLE_FLUSH_SUPPORT
 | |
| 	/* To flush output queue */
 | |
| 	void (*flush)(struct stdio_dev *dev);
 | |
| #define STDIO_DEV_ASSIGN_FLUSH(dev, flush_func) ((dev)->flush = (flush_func))
 | |
| #else
 | |
| #define STDIO_DEV_ASSIGN_FLUSH(dev, flush_func)
 | |
| #endif
 | |
| 
 | |
| /* INPUT functions */
 | |
| 
 | |
| 	/* To test if a char is ready... */
 | |
| 	int (*tstc)(struct stdio_dev *dev);
 | |
| 	int (*getc)(struct stdio_dev *dev);	/* To get that char */
 | |
| 
 | |
| /* Other functions */
 | |
| 
 | |
| 	void *priv;			/* Private extensions			*/
 | |
| 	struct list_head list;
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * VARIABLES
 | |
|  */
 | |
| extern struct stdio_dev *stdio_devices[];
 | |
| extern char *stdio_names[MAX_FILES];
 | |
| 
 | |
| /*
 | |
|  * PROTOTYPES
 | |
|  */
 | |
| int stdio_register(struct stdio_dev *dev);
 | |
| int stdio_register_dev(struct stdio_dev *dev, struct stdio_dev **devp);
 | |
| 
 | |
| /**
 | |
|  * stdio_init_tables() - set up stdio tables ready for devices
 | |
|  *
 | |
|  * This does not add any devices, but just prepares stdio for use.
 | |
|  */
 | |
| int stdio_init_tables(void);
 | |
| 
 | |
| /**
 | |
|  * stdio_add_devices() - Add stdio devices to the table
 | |
|  *
 | |
|  * This makes calls to all the various subsystems that use stdio, to make
 | |
|  * them register with stdio.
 | |
|  */
 | |
| int stdio_add_devices(void);
 | |
| 
 | |
| /**
 | |
|  * stdio_init() - Sets up stdio ready for use
 | |
|  *
 | |
|  * This calls stdio_init_tables() and stdio_add_devices()
 | |
|  */
 | |
| int stdio_init(void);
 | |
| 
 | |
| void stdio_print_current_devices(void);
 | |
| 
 | |
| /**
 | |
|  * stdio_deregister_dev() - deregister the device "devname".
 | |
|  *
 | |
|  * @dev: Stdio device to deregister
 | |
|  * @force: true to force deregistration even if in use
 | |
|  *
 | |
|  * returns 0 on success, -EBUSY if device is assigned
 | |
|  */
 | |
| int stdio_deregister_dev(struct stdio_dev *dev, int force);
 | |
| struct list_head *stdio_get_list(void);
 | |
| struct stdio_dev *stdio_get_by_name(const char *name);
 | |
| struct stdio_dev *stdio_clone(struct stdio_dev *dev);
 | |
| 
 | |
| int drv_lcd_init(void);
 | |
| int drv_video_init(void);
 | |
| int drv_keyboard_init(void);
 | |
| int drv_usbtty_init(void);
 | |
| int drv_usbacm_init(void);
 | |
| int drv_nc_init(void);
 | |
| int drv_jtag_console_init(void);
 | |
| int cbmemc_init(void);
 | |
| 
 | |
| #endif
 |