stdio: Pass device pointer to stdio methods
At present stdio device functions do not get any clue as to which stdio device is being acted on. Some implementations go to great lengths to work around this, such as defining a whole separate set of functions for each possible device. For driver model we need to associate a stdio_dev with a device. It doesn't seem possible to continue with this work-around approach. Instead, add a stdio_dev pointer to each of the stdio member functions. Note: The serial drivers have the same problem, but it is not strictly necessary to fix that to get driver model running. Also, if we convert serial over to driver model the problem will go away. Code size increases by 244 bytes for Thumb2 and 428 for PowerPC. 22: stdio: Pass device pointer to stdio methods arm: (for 2/2 boards) all +244.0 bss -4.0 text +248.0 powerpc: (for 1/1 boards) all +428.0 text +428.0 Signed-off-by: Simon Glass <sjg@chromium.org> Acked-by: Marek Vasut <marex@denx.de> Reviewed-by: Marek Vasut <marex@denx.de>
This commit is contained in:
@@ -639,6 +639,11 @@ void serial_puts (const char *);
|
||||
int serial_getc (void);
|
||||
int serial_tstc (void);
|
||||
|
||||
/* These versions take a stdio_dev pointer */
|
||||
struct stdio_dev;
|
||||
int serial_stub_getc(struct stdio_dev *sdev);
|
||||
int serial_stub_tstc(struct stdio_dev *sdev);
|
||||
|
||||
void _serial_setbrg (const int);
|
||||
void _serial_putc (const char, const int);
|
||||
void _serial_putc_raw(const char, const int);
|
||||
|
@@ -234,8 +234,8 @@
|
||||
#define CONFIG_VIDEO
|
||||
#define CONFIG_CFB_CONSOLE
|
||||
#define VIDEO_KBD_INIT_FCT (simple_strtol (getenv("console"), NULL, 10))
|
||||
#define VIDEO_TSTC_FCT serial_tstc
|
||||
#define VIDEO_GETC_FCT serial_getc
|
||||
#define VIDEO_TSTC_FCT serial_stub_tstc
|
||||
#define VIDEO_GETC_FCT serial_stub_getc
|
||||
|
||||
#define CONFIG_VIDEO_SMI_LYNXEM
|
||||
#define CONFIG_VIDEO_LOGO
|
||||
|
@@ -96,8 +96,8 @@
|
||||
#define CONFIG_VIDEO_LOGO
|
||||
|
||||
#define VIDEO_KBD_INIT_FCT 0 /* no KBD dev on MHPC - use serial */
|
||||
#define VIDEO_TSTC_FCT serial_tstc
|
||||
#define VIDEO_GETC_FCT serial_getc
|
||||
#define VIDEO_TSTC_FCT serial_stub_tstc
|
||||
#define VIDEO_GETC_FCT serial_stub_getc
|
||||
|
||||
#define CONFIG_BR0_WORKAROUND 1
|
||||
|
||||
|
@@ -87,8 +87,8 @@
|
||||
#define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE (800*480 + 256*4 + 10*1024)
|
||||
#define VIDEO_FB_16BPP_WORD_SWAP
|
||||
#define VIDEO_KBD_INIT_FCT 0
|
||||
#define VIDEO_TSTC_FCT serial_tstc
|
||||
#define VIDEO_GETC_FCT serial_getc
|
||||
#define VIDEO_TSTC_FCT serial_stub_tstc
|
||||
#define VIDEO_GETC_FCT serial_stub_getc
|
||||
|
||||
/*
|
||||
* BOOTP options
|
||||
|
@@ -263,9 +263,10 @@
|
||||
#define VIDEO_TSTC_FCT rx51_kp_tstc
|
||||
#define VIDEO_GETC_FCT rx51_kp_getc
|
||||
#ifndef __ASSEMBLY__
|
||||
struct stdio_dev;
|
||||
int rx51_kp_init(void);
|
||||
int rx51_kp_tstc(void);
|
||||
int rx51_kp_getc(void);
|
||||
int rx51_kp_tstc(struct stdio_dev *sdev);
|
||||
int rx51_kp_getc(struct stdio_dev *sdev);
|
||||
#endif
|
||||
|
||||
#ifndef MTDPARTS_DEFAULT
|
||||
|
@@ -72,8 +72,10 @@ void i8042_flush(void);
|
||||
*/
|
||||
int i8042_disable(void);
|
||||
|
||||
struct stdio_dev;
|
||||
|
||||
int i8042_kbd_init(void);
|
||||
int i8042_tstc(void);
|
||||
int i8042_getc(void);
|
||||
int i8042_tstc(struct stdio_dev *dev);
|
||||
int i8042_getc(struct stdio_dev *dev);
|
||||
|
||||
#endif /* _I8042_H_ */
|
||||
|
@@ -27,18 +27,21 @@ struct stdio_dev {
|
||||
|
||||
/* GENERAL functions */
|
||||
|
||||
int (*start) (void); /* To start the device */
|
||||
int (*stop) (void); /* To stop the device */
|
||||
int (*start)(struct stdio_dev *dev); /* To start the device */
|
||||
int (*stop)(struct stdio_dev *dev); /* To stop the device */
|
||||
|
||||
/* OUTPUT functions */
|
||||
|
||||
void (*putc) (const char c); /* To put a char */
|
||||
void (*puts) (const char *s); /* To put a string (accelerator) */
|
||||
/* 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);
|
||||
|
||||
/* INPUT functions */
|
||||
|
||||
int (*tstc) (void); /* To test if a char is ready... */
|
||||
int (*getc) (void); /* To get that char */
|
||||
/* 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 */
|
||||
|
||||
|
@@ -11,9 +11,11 @@
|
||||
|
||||
/* Video functions */
|
||||
|
||||
int video_init (void *videobase);
|
||||
void video_putc (const char c);
|
||||
void video_puts (const char *s);
|
||||
struct stdio_dev;
|
||||
|
||||
int video_init(void *videobase);
|
||||
void video_putc(struct stdio_dev *dev, const char c);
|
||||
void video_puts(struct stdio_dev *dev, const char *s);
|
||||
|
||||
/**
|
||||
* Display a BMP format bitmap on the screen
|
||||
|
Reference in New Issue
Block a user