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

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 7f11dc6 was 3266412, checked in by Aurelio Colosimo <aurelio@…>, 9 years ago

kconsole tab completion: implement args completion for 'describe' and 'symaddr'

  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*
2 * Copyright (c) 2005 Jakub Jermar
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
29/** @addtogroup genericconsole
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_KCONSOLE_H_
36#define KERN_KCONSOLE_H_
37
38#include <adt/list.h>
39#include <synch/spinlock.h>
40#include <ipc/irq.h>
41
42#define MAX_CMDLINE 256
43#define KCONSOLE_HISTORY 10
44
45/** Callback to be used to enum hints for cmd tab completion. */
46typedef const char *(*hints_enum_func_t)(const char *, const char **, void **);
47
48typedef enum {
49 ARG_TYPE_INVALID = 0,
50 ARG_TYPE_INT,
51 ARG_TYPE_STRING,
52 /** Optional string */
53 ARG_TYPE_STRING_OPTIONAL,
54 /** Variable type - either symbol or string. */
55 ARG_TYPE_VAR
56} cmd_arg_type_t;
57
58/** Structure representing one argument of kconsole command line. */
59typedef struct {
60 /** Type descriptor. */
61 cmd_arg_type_t type;
62 /** Buffer where to store data. */
63 void *buffer;
64 /** Size of the buffer. */
65 size_t len;
66 /** Integer value. */
67 sysarg_t intval;
68 /** Resulting type of variable arg */
69 cmd_arg_type_t vartype;
70} cmd_arg_t;
71
72/** Structure representing one kconsole command. */
73typedef struct {
74 /** Command list link. */
75 link_t link;
76 /** This lock protects everything below. */
77 SPINLOCK_DECLARE(lock);
78 /** Command name. */
79 const char *name;
80 /** Textual description. */
81 const char *description;
82 /** Function implementing the command. */
83 int (* func)(cmd_arg_t *);
84 /** Number of arguments. */
85 size_t argc;
86 /** Argument vector. */
87 cmd_arg_t *argv;
88 /** Function for printing detailed help. */
89 void (* help)(void);
90 /** Function for enumerating hints for arguments. */
91 hints_enum_func_t hints_enum;
92} cmd_info_t;
93
94extern bool kconsole_notify;
95extern irq_t kconsole_irq;
96
97SPINLOCK_EXTERN(cmd_lock);
98extern list_t cmd_list;
99
100extern void kconsole_init(void);
101extern void kconsole_notify_init(void);
102extern bool kconsole_check_poll(void);
103extern void kconsole(const char *prompt, const char *msg, bool kcon);
104extern void kconsole_thread(void *data);
105
106extern bool cmd_register(cmd_info_t *cmd);
107extern const char *cmdtab_enum(const char *name, const char **h, void **ctx);
108
109#endif
110
111/** @}
112 */
Note: See TracBrowser for help on using the repository browser.