source: mainline/kernel/generic/include/console/kconsole.h@ a000878c

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since a000878c was a000878c, checked in by Martin Decky <martin@…>, 15 years ago

make sure that all statically allocated strings are declared as "const char *"
and are treated as read-only

  • Property mode set to 100644
File size: 3.0 KB
RevLine 
[2677758]1/*
[df4ed85]2 * Copyright (c) 2005 Jakub Jermar
[2677758]3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
[06e1e95]29/** @addtogroup genericconsole
[b45c443]30 * @{
31 */
32/** @file
33 */
34
[06e1e95]35#ifndef KERN_KCONSOLE_H_
36#define KERN_KCONSOLE_H_
[2677758]37
[5c9a08b]38#include <adt/list.h>
[ff3b3197]39#include <synch/spinlock.h>
[3ad953c]40#include <ipc/irq.h>
[ff3b3197]41
[d6c8ff6]42#define MAX_CMDLINE 256
43#define KCONSOLE_HISTORY 10
[442d0ae]44
[b3f8fb7]45typedef enum {
[ff3b3197]46 ARG_TYPE_INVALID = 0,
47 ARG_TYPE_INT,
[91c78c9]48 ARG_TYPE_STRING,
[80bcaed]49 /** Variable type - either symbol or string. */
[d6c8ff6]50 ARG_TYPE_VAR
[b3f8fb7]51} cmd_arg_type_t;
[ff3b3197]52
53/** Structure representing one argument of kconsole command line. */
[b3f8fb7]54typedef struct {
[80bcaed]55 /** Type descriptor. */
56 cmd_arg_type_t type;
57 /** Buffer where to store data. */
58 void *buffer;
59 /** Size of the buffer. */
60 size_t len;
61 /** Integer value. */
62 unative_t intval;
63 /** Resulting type of variable arg */
64 cmd_arg_type_t vartype;
[b3f8fb7]65} cmd_arg_t;
[ff3b3197]66
67/** Structure representing one kconsole command. */
[b3f8fb7]68typedef struct {
[80bcaed]69 /** Command list link. */
70 link_t link;
71 /** This lock protects everything below. */
72 SPINLOCK_DECLARE(lock);
73 /** Command name. */
74 const char *name;
75 /** Textual description. */
76 const char *description;
77 /** Function implementing the command. */
78 int (* func)(cmd_arg_t *);
79 /** Number of arguments. */
[98000fb]80 size_t argc;
[80bcaed]81 /** Argument vector. */
82 cmd_arg_t *argv;
83 /** Function for printing detailed help. */
84 void (* help)(void);
[b3f8fb7]85} cmd_info_t;
[ff3b3197]86
[3ad953c]87extern bool kconsole_notify;
88extern irq_t kconsole_irq;
89
[8be8cfa]90SPINLOCK_EXTERN(cmd_lock);
[ff3b3197]91extern link_t cmd_head;
92
93extern void kconsole_init(void);
[3ad953c]94extern void kconsole_notify_init(void);
[a02e383]95extern bool kconsole_check_poll(void);
[a000878c]96extern void kconsole(const char *prompt, const char *msg, bool kcon);
[76fca31]97extern void kconsole_thread(void *data);
[2677758]98
[d6c8ff6]99extern bool cmd_register(cmd_info_t *cmd);
[ff3b3197]100
[2677758]101#endif
[b45c443]102
[06e1e95]103/** @}
[b45c443]104 */
Note: See TracBrowser for help on using the repository browser.