📄 polled_io.c
字号:
/* * polled_io.c -- Basic input/output for early boot * * Copyright (C) 1998, 1999 Gabriel Paubert, paubert@iram.es * * Modified to compile in RTEMS development environment * by Eric Valette * * Copyright (C) 1999 Eric Valette. valette@crf.canon.fr * * The license and distribution terms for this file may be * found in found in the file LICENSE in this distribution or at * http://www.rtems.com/license/LICENSE. * * $Id: polled_io.c,v 1.4.2.3 2003/09/04 18:45:20 joel Exp $ */#include <rtems/system.h>#include <sys/types.h>#include <libcpu/byteorder.h>#include <libcpu/page.h>#include <libcpu/mmu.h>#include <libcpu/io.h>#include <string.h>#include <stdarg.h>#include <bsp/consoleIo.h>#include <bsp.h>#include <libcpu/spr.h>#ifdef BSP_KBD_IOBASE#define USE_KBD_SUPPORT#endif#ifdef BSP_VGA_IOBASE#define USE_VGA_SUPPORT#endif#ifdef USE_KBD_SUPPORT#include "keyboard.h"#endif#include "console.inl"#ifdef __BOOT__extern void boot_udelay();void * __palloc(u_long);void pfree(void *);#else#include <rtems/bspIo.h>#endiftypedef unsigned long long u64;typedef long long s64;typedef unsigned int u32;#ifndef __BOOT__BSP_output_char_function_type BSP_output_char = debug_putc_onlcr;#endif#ifdef USE_KBD_SUPPORTunsigned short plain_map[NR_KEYS] = { 0xf200, 0xf01b, 0xf031, 0xf032, 0xf033, 0xf034, 0xf035, 0xf036, 0xf037, 0xf038, 0xf039, 0xf030, 0xf02d, 0xf03d, 0xf07f, 0xf009, 0xfb71, 0xfb77, 0xfb65, 0xfb72, 0xfb74, 0xfb79, 0xfb75, 0xfb69, 0xfb6f, 0xfb70, 0xf05b, 0xf05d, 0xf201, 0xf702, 0xfb61, 0xfb73, 0xfb64, 0xfb66, 0xfb67, 0xfb68, 0xfb6a, 0xfb6b, 0xfb6c, 0xf03b, 0xf027, 0xf060, 0xf700, 0xf05c, 0xfb7a, 0xfb78, 0xfb63, 0xfb76, 0xfb62, 0xfb6e, 0xfb6d, 0xf02c, 0xf02e, 0xf02f, 0xf700, 0xf30c, 0xf703, 0xf020, 0xf207, 0xf100, 0xf101, 0xf102, 0xf103, 0xf104, 0xf105, 0xf106, 0xf107, 0xf108, 0xf109, 0xf208, 0xf209, 0xf307, 0xf308, 0xf309, 0xf30b, 0xf304, 0xf305, 0xf306, 0xf30a, 0xf301, 0xf302, 0xf303, 0xf300, 0xf310, 0xf206, 0xf200, 0xf03c, 0xf10a, 0xf10b, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf01c, 0xf701, 0xf205, 0xf114, 0xf603, 0xf118, 0xf601, 0xf602, 0xf117, 0xf600, 0xf119, 0xf115, 0xf116, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};unsigned short shift_map[NR_KEYS] = { 0xf200, 0xf01b, 0xf021, 0xf040, 0xf023, 0xf024, 0xf025, 0xf05e, 0xf026, 0xf02a, 0xf028, 0xf029, 0xf05f, 0xf02b, 0xf07f, 0xf009, 0xfb51, 0xfb57, 0xfb45, 0xfb52, 0xfb54, 0xfb59, 0xfb55, 0xfb49, 0xfb4f, 0xfb50, 0xf07b, 0xf07d, 0xf201, 0xf702, 0xfb41, 0xfb53, 0xfb44, 0xfb46, 0xfb47, 0xfb48, 0xfb4a, 0xfb4b, 0xfb4c, 0xf03a, 0xf022, 0xf07e, 0xf700, 0xf07c, 0xfb5a, 0xfb58, 0xfb43, 0xfb56, 0xfb42, 0xfb4e, 0xfb4d, 0xf03c, 0xf03e, 0xf03f, 0xf700, 0xf30c, 0xf703, 0xf020, 0xf207, 0xf10a, 0xf10b, 0xf10c, 0xf10d, 0xf10e, 0xf10f, 0xf110, 0xf111, 0xf112, 0xf113, 0xf213, 0xf203, 0xf307, 0xf308, 0xf309, 0xf30b, 0xf304, 0xf305, 0xf306, 0xf30a, 0xf301, 0xf302, 0xf303, 0xf300, 0xf310, 0xf206, 0xf200, 0xf03e, 0xf10a, 0xf10b, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf200, 0xf701, 0xf205, 0xf114, 0xf603, 0xf20b, 0xf601, 0xf602, 0xf117, 0xf600, 0xf20a, 0xf115, 0xf116, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};unsigned short altgr_map[NR_KEYS] = { 0xf200, 0xf200, 0xf200, 0xf040, 0xf200, 0xf024, 0xf200, 0xf200, 0xf07b, 0xf05b, 0xf05d, 0xf07d, 0xf05c, 0xf200, 0xf200, 0xf200, 0xfb71, 0xfb77, 0xf918, 0xfb72, 0xfb74, 0xfb79, 0xfb75, 0xfb69, 0xfb6f, 0xfb70, 0xf200, 0xf07e, 0xf201, 0xf702, 0xf914, 0xfb73, 0xf917, 0xf919, 0xfb67, 0xfb68, 0xfb6a, 0xfb6b, 0xfb6c, 0xf200, 0xf200, 0xf200, 0xf700, 0xf200, 0xfb7a, 0xfb78, 0xf916, 0xfb76, 0xf915, 0xfb6e, 0xfb6d, 0xf200, 0xf200, 0xf200, 0xf700, 0xf30c, 0xf703, 0xf200, 0xf207, 0xf50c, 0xf50d, 0xf50e, 0xf50f, 0xf510, 0xf511, 0xf512, 0xf513, 0xf514, 0xf515, 0xf208, 0xf202, 0xf911, 0xf912, 0xf913, 0xf30b, 0xf90e, 0xf90f, 0xf910, 0xf30a, 0xf90b, 0xf90c, 0xf90d, 0xf90a, 0xf310, 0xf206, 0xf200, 0xf07c, 0xf516, 0xf517, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf200, 0xf701, 0xf205, 0xf114, 0xf603, 0xf118, 0xf601, 0xf602, 0xf117, 0xf600, 0xf119, 0xf115, 0xf116, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};unsigned short ctrl_map[NR_KEYS] = { 0xf200, 0xf200, 0xf200, 0xf000, 0xf01b, 0xf01c, 0xf01d, 0xf01e, 0xf01f, 0xf07f, 0xf200, 0xf200, 0xf01f, 0xf200, 0xf008, 0xf200, 0xf011, 0xf017, 0xf005, 0xf012, 0xf014, 0xf019, 0xf015, 0xf009, 0xf00f, 0xf010, 0xf01b, 0xf01d, 0xf201, 0xf702, 0xf001, 0xf013, 0xf004, 0xf006, 0xf007, 0xf008, 0xf00a, 0xf00b, 0xf00c, 0xf200, 0xf007, 0xf000, 0xf700, 0xf01c, 0xf01a, 0xf018, 0xf003, 0xf016, 0xf002, 0xf00e, 0xf00d, 0xf200, 0xf20e, 0xf07f, 0xf700, 0xf30c, 0xf703, 0xf000, 0xf207, 0xf100, 0xf101, 0xf102, 0xf103, 0xf104, 0xf105, 0xf106, 0xf107, 0xf108, 0xf109, 0xf208, 0xf204, 0xf307, 0xf308, 0xf309, 0xf30b, 0xf304, 0xf305, 0xf306, 0xf30a, 0xf301, 0xf302, 0xf303, 0xf300, 0xf310, 0xf206, 0xf200, 0xf200, 0xf10a, 0xf10b, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf01c, 0xf701, 0xf205, 0xf114, 0xf603, 0xf118, 0xf601, 0xf602, 0xf117, 0xf600, 0xf119, 0xf115, 0xf116, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};unsigned short shift_ctrl_map[NR_KEYS] = { 0xf200, 0xf200, 0xf200, 0xf000, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf01f, 0xf200, 0xf200, 0xf200, 0xf011, 0xf017, 0xf005, 0xf012, 0xf014, 0xf019, 0xf015, 0xf009, 0xf00f, 0xf010, 0xf200, 0xf200, 0xf201, 0xf702, 0xf001, 0xf013, 0xf004, 0xf006, 0xf007, 0xf008, 0xf00a, 0xf00b, 0xf00c, 0xf200, 0xf200, 0xf200, 0xf700, 0xf200, 0xf01a, 0xf018, 0xf003, 0xf016, 0xf002, 0xf00e, 0xf00d, 0xf200, 0xf200, 0xf200, 0xf700, 0xf30c, 0xf703, 0xf200, 0xf207, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf208, 0xf200, 0xf307, 0xf308, 0xf309, 0xf30b, 0xf304, 0xf305, 0xf306, 0xf30a, 0xf301, 0xf302, 0xf303, 0xf300, 0xf310, 0xf206, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf200, 0xf701, 0xf205, 0xf114, 0xf603, 0xf118, 0xf601, 0xf602, 0xf117, 0xf600, 0xf119, 0xf115, 0xf116, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};unsigned short alt_map[NR_KEYS] = { 0xf200, 0xf81b, 0xf831, 0xf832, 0xf833, 0xf834, 0xf835, 0xf836, 0xf837, 0xf838, 0xf839, 0xf830, 0xf82d, 0xf83d, 0xf87f, 0xf809, 0xf871, 0xf877, 0xf865, 0xf872, 0xf874, 0xf879, 0xf875, 0xf869, 0xf86f, 0xf870, 0xf85b, 0xf85d, 0xf80d, 0xf702, 0xf861, 0xf873, 0xf864, 0xf866, 0xf867, 0xf868, 0xf86a, 0xf86b, 0xf86c, 0xf83b, 0xf827, 0xf860, 0xf700, 0xf85c, 0xf87a, 0xf878, 0xf863, 0xf876, 0xf862, 0xf86e, 0xf86d, 0xf82c, 0xf82e, 0xf82f, 0xf700, 0xf30c, 0xf703, 0xf820, 0xf207, 0xf500, 0xf501, 0xf502, 0xf503, 0xf504, 0xf505, 0xf506, 0xf507, 0xf508, 0xf509, 0xf208, 0xf209, 0xf907, 0xf908, 0xf909, 0xf30b, 0xf904, 0xf905, 0xf906, 0xf30a, 0xf901, 0xf902, 0xf903, 0xf900, 0xf310, 0xf206, 0xf200, 0xf83c, 0xf50a, 0xf50b, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf01c, 0xf701, 0xf205, 0xf114, 0xf603, 0xf118, 0xf210, 0xf211, 0xf117, 0xf600, 0xf119, 0xf115, 0xf116, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};unsigned short ctrl_alt_map[NR_KEYS] = { 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf811, 0xf817, 0xf805, 0xf812, 0xf814, 0xf819, 0xf815, 0xf809, 0xf80f, 0xf810, 0xf200, 0xf200, 0xf201, 0xf702, 0xf801, 0xf813, 0xf804, 0xf806, 0xf807, 0xf808, 0xf80a, 0xf80b, 0xf80c, 0xf200, 0xf200, 0xf200, 0xf700, 0xf200, 0xf81a, 0xf818, 0xf803, 0xf816, 0xf802, 0xf80e, 0xf80d, 0xf200, 0xf200, 0xf200, 0xf700, 0xf30c, 0xf703, 0xf200, 0xf207, 0xf500, 0xf501, 0xf502, 0xf503, 0xf504, 0xf505, 0xf506, 0xf507, 0xf508, 0xf509, 0xf208, 0xf200, 0xf307, 0xf308, 0xf309, 0xf30b, 0xf304, 0xf305, 0xf306, 0xf30a, 0xf301, 0xf302, 0xf303, 0xf300, 0xf20c, 0xf206, 0xf200, 0xf200, 0xf50a, 0xf50b, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf30e, 0xf702, 0xf30d, 0xf200, 0xf701, 0xf205, 0xf114, 0xf603, 0xf118, 0xf601, 0xf602, 0xf117, 0xf600, 0xf119, 0xf115, 0xf20c, 0xf11a, 0xf10c, 0xf10d, 0xf11b, 0xf11c, 0xf110, 0xf311, 0xf11d, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200, 0xf200,};ushort *key_maps[MAX_NR_KEYMAPS] = { plain_map, shift_map, altgr_map, 0, ctrl_map, shift_ctrl_map, 0, 0, alt_map, 0, 0, 0, ctrl_alt_map, 0};unsigned int keymap_count = 7;/* * Philosophy: most people do not define more strings, but they who do * often want quite a lot of string space. So, we statically allocate * the default and allocate dynamically in chunks of 512 bytes. */char func_buf[] = { '\033', '[', '[', 'A', 0, '\033', '[', '[', 'B', 0, '\033', '[', '[', 'C', 0, '\033', '[', '[', 'D', 0, '\033', '[', '[', 'E', 0, '\033', '[', '1', '7', '~', 0, '\033', '[', '1', '8', '~', 0, '\033', '[', '1', '9', '~', 0, '\033', '[', '2', '0', '~', 0, '\033', '[', '2', '1', '~', 0, '\033', '[', '2', '3', '~', 0, '\033', '[', '2', '4', '~', 0, '\033', '[', '2', '5', '~', 0, '\033', '[', '2', '6', '~', 0, '\033', '[', '2', '8', '~', 0, '\033', '[', '2', '9', '~', 0, '\033', '[', '3', '1', '~', 0, '\033', '[', '3', '2', '~', 0, '\033', '[', '3', '3', '~', 0, '\033', '[', '3', '4', '~', 0, '\033', '[', '1', '~', 0, '\033', '[', '2', '~', 0, '\033', '[', '3', '~', 0, '\033', '[', '4', '~', 0, '\033', '[', '5', '~', 0, '\033', '[', '6', '~', 0, '\033', '[', 'M', 0, '\033', '[', 'P', 0, };char *funcbufptr = func_buf;int funcbufsize = sizeof(func_buf);int funcbufleft = 0; /* space left */char *func_table[MAX_NR_FUNC] = { func_buf + 0, func_buf + 5, func_buf + 10, func_buf + 15, func_buf + 20, func_buf + 25, func_buf + 31, func_buf + 37, func_buf + 43, func_buf + 49, func_buf + 55, func_buf + 61, func_buf + 67, func_buf + 73, func_buf + 79, func_buf + 85, func_buf + 91, func_buf + 97, func_buf + 103, func_buf + 109, func_buf + 115, func_buf + 120, func_buf + 125, func_buf + 130, func_buf + 135, func_buf + 140, func_buf + 145, 0, 0, func_buf + 149, 0,};struct kbdiacr { unsigned char diacr, base, result;};struct kbdiacr accent_table[MAX_DIACR] = { {'`', 'A', '\300'}, {'`', 'a', '\340'}, {'\'', 'A', '\301'}, {'\'', 'a', '\341'}, {'^', 'A', '\302'}, {'^', 'a', '\342'}, {'~', 'A', '\303'}, {'~', 'a', '\343'}, {'"', 'A', '\304'}, {'"', 'a', '\344'}, {'O', 'A', '\305'}, {'o', 'a', '\345'}, {'0', 'A', '\305'}, {'0', 'a', '\345'}, {'A', 'A', '\305'}, {'a', 'a', '\345'}, {'A', 'E', '\306'}, {'a', 'e', '\346'}, {',', 'C', '\307'}, {',', 'c', '\347'}, {'`', 'E', '\310'}, {'`', 'e', '\350'}, {'\'', 'E', '\311'}, {'\'', 'e', '\351'}, {'^', 'E', '\312'}, {'^', 'e', '\352'}, {'"', 'E', '\313'}, {'"', 'e', '\353'}, {'`', 'I', '\314'}, {'`', 'i', '\354'}, {'\'', 'I', '\315'}, {'\'', 'i', '\355'}, {'^', 'I', '\316'}, {'^', 'i', '\356'}, {'"', 'I', '\317'}, {'"', 'i', '\357'}, {'-', 'D', '\320'}, {'-', 'd', '\360'}, {'~', 'N', '\321'}, {'~', 'n', '\361'}, {'`', 'O', '\322'}, {'`', 'o', '\362'}, {'\'', 'O', '\323'}, {'\'', 'o', '\363'}, {'^', 'O', '\324'}, {'^', 'o', '\364'}, {'~', 'O', '\325'}, {'~', 'o', '\365'}, {'"', 'O', '\326'}, {'"', 'o', '\366'}, {'/', 'O', '\330'}, {'/', 'o', '\370'}, {'`', 'U', '\331'}, {'`', 'u', '\371'}, {'\'', 'U', '\332'}, {'\'', 'u', '\372'}, {'^', 'U', '\333'}, {'^', 'u', '\373'}, {'"', 'U', '\334'}, {'"', 'u', '\374'}, {'\'', 'Y', '\335'}, {'\'', 'y', '\375'}, {'T', 'H', '\336'}, {'t', 'h', '\376'}, {'s', 's', '\337'}, {'"', 'y', '\377'}, {'s', 'z', '\337'}, {'i', 'j', '\377'},};unsigned int accent_table_size = 68;/* These #defines have been copied from drivers/char/pc_keyb.h, by * Martin Mares (mj@ucw.cz). * converted to offsets by Till Straumann <strauman@slac.stanford.edu> */#define KBD_STATUS_REG 0x4 /* Status register (R) */#define KBD_CNTL_REG 0x4 /* Controller command register (W) */#define KBD_DATA_REG 0x0 /* Keyboard data register (R/W) *//* * Keyboard Controller Commands */#define KBD_CCMD_WRITE_MODE 0x60 /* Write mode bits */#define KBD_CCMD_GET_VERSION 0xA1 /* Get controller version */#define KBD_CCMD_MOUSE_DISABLE 0xA7 /* Disable mouse interface */#define KBD_CCMD_MOUSE_ENABLE 0xA8 /* Enable mouse interface */#define KBD_CCMD_TEST_MOUSE 0xA9 /* Mouse interface test */#define KBD_CCMD_SELF_TEST 0xAA /* Controller self test */#define KBD_CCMD_KBD_TEST 0xAB /* Keyboard interface test */#define KBD_CCMD_KBD_DISABLE 0xAD /* Keyboard interface disable */#define KBD_CCMD_KBD_ENABLE 0xAE /* Keyboard interface enable *//* * Keyboard Commands */#define KBD_CMD_ENABLE 0xF4 /* Enable scanning */#define KBD_CMD_DISABLE 0xF5 /* Disable scanning */#define KBD_CMD_RESET 0xFF /* Reset *//* * Keyboard Replies */#define KBD_REPLY_POR 0xAA /* Power on reset */#define KBD_REPLY_ACK 0xFA /* Command ACK */#define KBD_REPLY_RESEND 0xFE /* Command NACK, send the cmd again *//* * Status Register Bits */#define KBD_STAT_OBF 0x01 /* Keyboard output buffer full */#define KBD_STAT_IBF 0x02 /* Keyboard input buffer full */#define KBD_STAT_UNLOCKED 0x10 /* Zero if keyboard locked */#define KBD_STAT_GTO 0x40 /* General receive/xmit timeout */#define KBD_STAT_PERR 0x80 /* Parity error *//* * Controller Mode Register Bits */#define KBD_MODE_KBD_INT 0x01 /* Keyboard data generate IRQ1 */#define KBD_MODE_SYS 0x04 /* The system flag (?) */#define KBD_MODE_NO_KEYLOCK 0x08 /* The keylock doesn't affect the keyboard if set */#define KBD_MODE_DISABLE_KBD 0x10 /* Disable keyboard interface */#define KBD_MODE_DISABLE_MOUSE 0x20 /* Disable mouse interface */#define KBD_MODE_KCC 0x40 /* Scan code conversion to PC format */#define KBD_MODE_RFU 0x80SPR_RW(DEC)SPR_RO(PVR)#endif /* USE_KBD_SUPPORT *//* Early messages after mm init but before console init are kept in log * buffers. */#define PAGE_LOG_CHARS (PAGE_SIZE-sizeof(int)-sizeof(u_long)-1)typedef struct _console_log { struct _console_log *next; int offset; u_char data[PAGE_LOG_CHARS];} console_log;#ifdef STATIC_LOG_ALLOC#define STATIC_LOG_DATA_PAGE_NB 3static u_char log_page_pool [STATIC_LOG_DATA_PAGE_NB * PAGE_SIZE];#endifstatic board_memory_map mem_map = { (__io_ptr) _IO_BASE, /* from libcpu/io.h */ (__io_ptr) _ISA_MEM_BASE,};board_memory_map *ptr_mem_map = &mem_map;struct _console_global_data { console_log *log; int vacuum_sent; int lines; int cols; int orig_x; int orig_y; u_char shfts, ctls, alts, caps;} console_global_data = {NULL, 0, 25, 80, 0, 24, 0, 0, 0, 0};typedef struct console_io { void (*putc) (const u_char); int (*getc) (void); int (*tstc) (void);}console_io;extern console_io* curIo;void debug_putc(const u_char c){ curIo->putc(c);}/* const char arg to be compatible with BSP_output_char decl. */voiddebug_putc_onlcr(const char c){ if ('\n'==c) debug_putc('\r'); debug_putc(c);}int debug_getc(void){ return curIo->getc();}int debug_tstc(void){ return curIo->tstc();}#define vidmem ((__io_ptr)(ptr_mem_map->isa_mem_base+0xb8000))void vacuum_putc(u_char c) { console_global_data.vacuum_sent++;}int vacuum_getc(void) { return -1;}int vacuum_tstc(void) { return 0;}/* * COM1 NS16550 support */#define rbr 0#define ier 1#define fcr 2#define lcr 3#define mcr 4#define lsr 5#define msr 6#define scr 7#define thr rbr#define iir fcr#define dll rbr#define dlm ier#define LSR_DR 0x01 /* Data ready */#define LSR_OE 0x02 /* Overrun */#define LSR_PE 0x04 /* Parity error */#define LSR_FE 0x08 /* Framing error */#define LSR_BI 0x10 /* Break */#define LSR_THRE 0x20 /* Xmit holding register empty */#define LSR_TEMT 0x40 /* Xmitter empty */#define LSR_ERR 0x80 /* Error */#ifdef STATIC_LOG_ALLOCstatic int global_index = 0;static void *__palloc(int s){ if (global_index ==( STATIC_LOG_DATA_PAGE_NB - 1) ) return (void*) 0; return (void*) &(log_page_pool [PAGE_SIZE * global_index++]);}static void pfree(void* p){ --global_index;}#endif void log_putc(const u_char c) { console_log *l; for(l=console_global_data.log; l; l=l->next) { if (l->offset<PAGE_LOG_CHARS) break; } if (!l) { l=__palloc(sizeof(console_log)); memset(l, 0, sizeof(console_log)); if (!console_global_data.log) console_global_data.log = l; else { console_log *p; for (p=console_global_data.log; p->next; p=p->next); p->next = l; } } l->data[l->offset++] = c;}/* This puts is non standard since it does not automatically add a newline * at the end. So it is made private to avoid confusion in other files. */static void puts(const u_char *s){ char c; while ( ( c = *s++ ) != '\0' ) { debug_putc_onlcr((const char)c); }}staticvoid flush_log(void) { console_log *p, *next; if (console_global_data.vacuum_sent) {#ifdef TRACE_FLUSH_LOG printk("%d characters sent into oblivion before MM init!\n", console_global_data.vacuum_sent);#endif } for(p=console_global_data.log; p; p=next) { puts(p->data); next = p->next; pfree(p); }}#ifndef INL_CONSOLE_INB
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -