mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-17 18:56:24 +00:00
1d6da87a32
Pull drm updates from Dave Airlie: "Here's the main drm pull request for 4.7, it's been a busy one, and I've been a bit more distracted in real life this merge window. Lots more ARM drivers, not sure if it'll ever end. I think I've at least one more coming the next merge window. But changes are all over the place, support for AMD Polaris GPUs is in here, some missing GM108 support for nouveau (found in some Lenovos), a bunch of MST and skylake fixes. I've also noticed a few fixes from Arnd in my inbox, that I'll try and get in asap, but I didn't think they should hold this up. New drivers: - Hisilicon kirin display driver - Mediatek MT8173 display driver - ARC PGU - bitstreamer on Synopsys ARC SDP boards - Allwinner A13 initial RGB output driver - Analogix driver for DisplayPort IP found in exynos and rockchip DRM Core: - UAPI headers fixes and C++ safety - DRM connector reference counting - DisplayID mode parsing for Dell 5K monitors - Removal of struct_mutex from drivers - Connector registration cleanups - MST robustness fixes - MAINTAINERS updates - Lockless GEM object freeing - Generic fbdev deferred IO support panel: - Support for a bunch of new panels i915: - VBT refactoring - PLL computation cleanups - DSI support for BXT - Color manager support - More atomic patches - GEM improvements - GuC fw loading fixes - DP detection fixes - SKL GPU hang fixes - Lots of BXT fixes radeon/amdgpu: - Initial Polaris support - GPUVM/Scheduler/Clock/Power improvements - ASYNC pageflip support - New mesa feature support nouveau: - GM108 support - Power sensor support improvements - GR init + ucode fixes. - Use GPU provided topology information vmwgfx: - Add host messaging support gma500: - Some cleanups and fixes atmel: - Bridge support - Async atomic commit support fsl-dcu: - Timing controller for LCD support - Pixel clock polarity support rcar-du: - Misc fixes exynos: - Pipeline clock support - Exynoss4533 SoC support - HW trigger mode support - export HDMI_PHY clock - DECON5433 fixes - Use generic prime functions - use DMA mapping APIs rockchip: - Lots of little fixes vc4: - Render node support - Gamma ramp support - DPI output support msm: - Mostly cleanups and fixes - Conversion to generic struct fence etnaviv: - Fix for prime buffer handling - Allow hangcheck to be coalesced with other wakeups tegra: - Gamme table size fix" * 'drm-next' of git://people.freedesktop.org/~airlied/linux: (1050 commits) drm/edid: add displayid detailed 1 timings to the modelist. (v1.1) drm/edid: move displayid validation to it's own function. drm/displayid: Iterate over all DisplayID blocks drm/edid: move displayid tiled block parsing into separate function. drm: Nuke ->vblank_disable_allowed drm/vmwgfx: Report vmwgfx version to vmware.log drm/vmwgfx: Add VMWare host messaging capability drm/vmwgfx: Kill some lockdep warnings drm/nouveau/gr/gf100-: fix race condition in fecs/gpccs ucode drm/nouveau/core: recognise GM108 chipsets drm/nouveau/gr/gm107-: fix touching non-existent ppcs in attrib cb setup drm/nouveau/gr/gk104-: share implementation of ppc exception init drm/nouveau/gr/gk104-: move rop_active_fbps init to nonctx drm/nouveau/bios/pll: check BIT table version before trying to parse it drm/nouveau/bios/pll: prevent oops when limits table can't be parsed drm/nouveau/volt/gk104: round up in gk104_volt_set drm/nouveau/fb/gm200: setup mmu debug buffer registers at init() drm/nouveau/fb/gk20a,gm20b: setup mmu debug buffer registers at init() drm/nouveau/fb/gf100-: allocate mmu debug buffers drm/nouveau/fb: allow chipset-specific actions for oneinit() ...
199 lines
6.1 KiB
C
199 lines
6.1 KiB
C
/*
|
|
* linux/include/linux/console.h
|
|
*
|
|
* Copyright (C) 1993 Hamish Macdonald
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file COPYING in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Changed:
|
|
* 10-Mar-94: Arno Griffioen: Conversion for vt100 emulator port from PC LINUX
|
|
*/
|
|
|
|
#ifndef _LINUX_CONSOLE_H_
|
|
#define _LINUX_CONSOLE_H_ 1
|
|
|
|
#include <linux/types.h>
|
|
|
|
struct vc_data;
|
|
struct console_font_op;
|
|
struct console_font;
|
|
struct module;
|
|
struct tty_struct;
|
|
|
|
/*
|
|
* this is what the terminal answers to a ESC-Z or csi0c query.
|
|
*/
|
|
#define VT100ID "\033[?1;2c"
|
|
#define VT102ID "\033[?6c"
|
|
|
|
struct consw {
|
|
struct module *owner;
|
|
const char *(*con_startup)(void);
|
|
void (*con_init)(struct vc_data *, int);
|
|
void (*con_deinit)(struct vc_data *);
|
|
void (*con_clear)(struct vc_data *, int, int, int, int);
|
|
void (*con_putc)(struct vc_data *, int, int, int);
|
|
void (*con_putcs)(struct vc_data *, const unsigned short *, int, int, int);
|
|
void (*con_cursor)(struct vc_data *, int);
|
|
int (*con_scroll)(struct vc_data *, int, int, int, int);
|
|
void (*con_bmove)(struct vc_data *, int, int, int, int, int, int);
|
|
int (*con_switch)(struct vc_data *);
|
|
int (*con_blank)(struct vc_data *, int, int);
|
|
int (*con_font_set)(struct vc_data *, struct console_font *, unsigned);
|
|
int (*con_font_get)(struct vc_data *, struct console_font *);
|
|
int (*con_font_default)(struct vc_data *, struct console_font *, char *);
|
|
int (*con_font_copy)(struct vc_data *, int);
|
|
int (*con_resize)(struct vc_data *, unsigned int, unsigned int,
|
|
unsigned int);
|
|
int (*con_set_palette)(struct vc_data *, const unsigned char *);
|
|
int (*con_scrolldelta)(struct vc_data *, int);
|
|
int (*con_set_origin)(struct vc_data *);
|
|
void (*con_save_screen)(struct vc_data *);
|
|
u8 (*con_build_attr)(struct vc_data *, u8, u8, u8, u8, u8, u8);
|
|
void (*con_invert_region)(struct vc_data *, u16 *, int);
|
|
u16 *(*con_screen_pos)(struct vc_data *, int);
|
|
unsigned long (*con_getxy)(struct vc_data *, unsigned long, int *, int *);
|
|
/*
|
|
* Prepare the console for the debugger. This includes, but is not
|
|
* limited to, unblanking the console, loading an appropriate
|
|
* palette, and allowing debugger generated output.
|
|
*/
|
|
int (*con_debug_enter)(struct vc_data *);
|
|
/*
|
|
* Restore the console to its pre-debug state as closely as possible.
|
|
*/
|
|
int (*con_debug_leave)(struct vc_data *);
|
|
};
|
|
|
|
extern const struct consw *conswitchp;
|
|
|
|
extern const struct consw dummy_con; /* dummy console buffer */
|
|
extern const struct consw vga_con; /* VGA text console */
|
|
extern const struct consw newport_con; /* SGI Newport console */
|
|
extern const struct consw prom_con; /* SPARC PROM console */
|
|
|
|
int con_is_bound(const struct consw *csw);
|
|
int do_unregister_con_driver(const struct consw *csw);
|
|
int do_take_over_console(const struct consw *sw, int first, int last, int deflt);
|
|
void give_up_console(const struct consw *sw);
|
|
#ifdef CONFIG_HW_CONSOLE
|
|
int con_debug_enter(struct vc_data *vc);
|
|
int con_debug_leave(void);
|
|
#else
|
|
static inline int con_debug_enter(struct vc_data *vc)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int con_debug_leave(void)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
/* scroll */
|
|
#define SM_UP (1)
|
|
#define SM_DOWN (2)
|
|
|
|
/* cursor */
|
|
#define CM_DRAW (1)
|
|
#define CM_ERASE (2)
|
|
#define CM_MOVE (3)
|
|
|
|
/*
|
|
* The interface for a console, or any other device that wants to capture
|
|
* console messages (printer driver?)
|
|
*
|
|
* If a console driver is marked CON_BOOT then it will be auto-unregistered
|
|
* when the first real console is registered. This is for early-printk drivers.
|
|
*/
|
|
|
|
#define CON_PRINTBUFFER (1)
|
|
#define CON_CONSDEV (2) /* Last on the command line */
|
|
#define CON_ENABLED (4)
|
|
#define CON_BOOT (8)
|
|
#define CON_ANYTIME (16) /* Safe to call when cpu is offline */
|
|
#define CON_BRL (32) /* Used for a braille device */
|
|
#define CON_EXTENDED (64) /* Use the extended output format a la /dev/kmsg */
|
|
|
|
struct console {
|
|
char name[16];
|
|
void (*write)(struct console *, const char *, unsigned);
|
|
int (*read)(struct console *, char *, unsigned);
|
|
struct tty_driver *(*device)(struct console *, int *);
|
|
void (*unblank)(void);
|
|
int (*setup)(struct console *, char *);
|
|
int (*match)(struct console *, char *name, int idx, char *options);
|
|
short flags;
|
|
short index;
|
|
int cflag;
|
|
void *data;
|
|
struct console *next;
|
|
};
|
|
|
|
/*
|
|
* for_each_console() allows you to iterate on each console
|
|
*/
|
|
#define for_each_console(con) \
|
|
for (con = console_drivers; con != NULL; con = con->next)
|
|
|
|
extern int console_set_on_cmdline;
|
|
extern struct console *early_console;
|
|
|
|
extern int add_preferred_console(char *name, int idx, char *options);
|
|
extern void register_console(struct console *);
|
|
extern int unregister_console(struct console *);
|
|
extern struct console *console_drivers;
|
|
extern void console_lock(void);
|
|
extern int console_trylock(void);
|
|
extern void console_unlock(void);
|
|
extern void console_conditional_schedule(void);
|
|
extern void console_unblank(void);
|
|
extern void console_flush_on_panic(void);
|
|
extern struct tty_driver *console_device(int *);
|
|
extern void console_stop(struct console *);
|
|
extern void console_start(struct console *);
|
|
extern int is_console_locked(void);
|
|
extern int braille_register_console(struct console *, int index,
|
|
char *console_options, char *braille_options);
|
|
extern int braille_unregister_console(struct console *);
|
|
#ifdef CONFIG_TTY
|
|
extern void console_sysfs_notify(void);
|
|
#else
|
|
static inline void console_sysfs_notify(void)
|
|
{ }
|
|
#endif
|
|
extern bool console_suspend_enabled;
|
|
|
|
/* Suspend and resume console messages over PM events */
|
|
extern void suspend_console(void);
|
|
extern void resume_console(void);
|
|
|
|
int mda_console_init(void);
|
|
void prom_con_init(void);
|
|
|
|
void vcs_make_sysfs(int index);
|
|
void vcs_remove_sysfs(int index);
|
|
|
|
/* Some debug stub to catch some of the obvious races in the VT code */
|
|
#if 1
|
|
#define WARN_CONSOLE_UNLOCKED() WARN_ON(!is_console_locked() && !oops_in_progress)
|
|
#else
|
|
#define WARN_CONSOLE_UNLOCKED()
|
|
#endif
|
|
|
|
/* VESA Blanking Levels */
|
|
#define VESA_NO_BLANKING 0
|
|
#define VESA_VSYNC_SUSPEND 1
|
|
#define VESA_HSYNC_SUSPEND 2
|
|
#define VESA_POWERDOWN 3
|
|
|
|
#ifdef CONFIG_VGA_CONSOLE
|
|
extern bool vgacon_text_force(void);
|
|
#else
|
|
static inline bool vgacon_text_force(void) { return false; }
|
|
#endif
|
|
|
|
#endif /* _LINUX_CONSOLE_H */
|