2006-03-27 23:25:16 +04:00
/*
* hvc_console . h
* Copyright ( C ) 2005 IBM Corporation
*
* Author ( s ) :
* Ryan S . Arnold < rsa @ us . ibm . com >
*
* hvc_console header information :
2008-08-01 09:20:30 +04:00
* moved here from arch / powerpc / include / asm / hvconsole . h
2006-03-27 23:25:16 +04:00
* and drivers / char / hvc_console . c
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
# ifndef HVC_CONSOLE_H
# define HVC_CONSOLE_H
2008-06-20 17:24:08 +04:00
# include <linux/kref.h>
2008-10-14 09:02:09 +04:00
# include <linux/tty.h>
2009-08-27 05:45:39 +04:00
# include <linux/spinlock.h>
2006-03-27 23:25:16 +04:00
/*
* This is the max number of console adapters that can / will be found as
* console devices on first stage console init . Any number beyond this range
* can ' t be used as a console device but is still a valid tty device .
*/
# define MAX_NR_HVC_CONSOLES 16
/*
* The Linux TTY code does not support dynamic addition of tty derived devices
* so we need to know how many tty devices we might need when space is allocated
* for the tty device . Since this driver supports hotplug of vty adapters we
* need to make sure we have enough allocated .
*/
# define HVC_ALLOC_TTY_ADAPTERS 8
2008-06-20 17:24:08 +04:00
struct hvc_struct {
spinlock_t lock ;
int index ;
struct tty_struct * tty ;
2008-12-02 14:21:43 +03:00
int count ;
2008-06-20 17:24:08 +04:00
int do_wakeup ;
char * outbuf ;
int outbuf_size ;
int n_outbuf ;
uint32_t vtermno ;
struct hv_ops * ops ;
int irq_requested ;
int data ;
2008-10-14 09:02:09 +04:00
struct winsize ws ;
struct work_struct tty_resize ;
2008-06-20 17:24:08 +04:00
struct list_head next ;
struct kref kref ; /* ref count & hvc_struct lifetime */
} ;
2006-03-27 23:25:16 +04:00
/* implemented by a low level driver */
struct hv_ops {
int ( * get_chars ) ( uint32_t vtermno , char * buf , int count ) ;
int ( * put_chars ) ( uint32_t vtermno , const char * buf , int count ) ;
2008-10-14 03:12:48 +04:00
/* Callbacks for notification. Called in open, close and hangup */
2008-06-20 17:24:08 +04:00
int ( * notifier_add ) ( struct hvc_struct * hp , int irq ) ;
void ( * notifier_del ) ( struct hvc_struct * hp , int irq ) ;
2008-10-14 03:12:48 +04:00
void ( * notifier_hangup ) ( struct hvc_struct * hp , int irq ) ;
2008-06-20 17:24:08 +04:00
} ;
2006-03-27 23:25:16 +04:00
/* Register a vterm and a slot index for use as a console (console_init) */
extern int hvc_instantiate ( uint32_t vtermno , int index , struct hv_ops * ops ) ;
/* register a vterm for hvc tty operation (module_init or hotplug add) */
2008-06-20 17:24:08 +04:00
extern struct hvc_struct * __devinit hvc_alloc ( uint32_t vtermno , int data ,
2006-07-13 12:53:32 +04:00
struct hv_ops * ops , int outbuf_size ) ;
2008-06-20 17:24:08 +04:00
/* remove a vterm from hvc tty operation (module_exit or hotplug remove) */
2008-10-14 03:12:52 +04:00
extern int hvc_remove ( struct hvc_struct * hp ) ;
2006-03-27 23:25:16 +04:00
2008-06-20 17:24:08 +04:00
/* data available */
int hvc_poll ( struct hvc_struct * hp ) ;
void hvc_kick ( void ) ;
2008-10-14 09:02:09 +04:00
/* Resize hvc tty terminal window */
2009-08-27 05:45:39 +04:00
extern void __hvc_resize ( struct hvc_struct * hp , struct winsize ws ) ;
static inline void hvc_resize ( struct hvc_struct * hp , struct winsize ws )
{
unsigned long flags ;
spin_lock_irqsave ( & hp - > lock , flags ) ;
__hvc_resize ( hp , ws ) ;
spin_unlock_irqrestore ( & hp - > lock , flags ) ;
}
2008-10-14 09:02:09 +04:00
2008-06-20 17:24:08 +04:00
/* default notifier for irq based notification */
extern int notifier_add_irq ( struct hvc_struct * hp , int data ) ;
extern void notifier_del_irq ( struct hvc_struct * hp , int data ) ;
2008-10-14 03:12:48 +04:00
extern void notifier_hangup_irq ( struct hvc_struct * hp , int data ) ;
2008-06-20 17:24:08 +04:00
2008-05-08 08:27:17 +04:00
# if defined(CONFIG_XMON) && defined(CONFIG_SMP)
# include <asm/xmon.h>
# else
static inline int cpus_are_in_xmon ( void )
{
return 0 ;
}
# endif
2006-03-27 23:25:16 +04:00
# endif // HVC_CONSOLE_H