Adding upstream version 4.00~pre54+dfsg.
[syslinux-debian/hramrach.git] / com32 / hdt / hdt-cli-hdt.c
blob65bb44446314d30581ed79e41e42883a94da64d3
1 /* ----------------------------------------------------------------------- *
3 * Copyright 2009 Pierre-Alexandre Meyer - All Rights Reserved
5 * Permission is hereby granted, free of charge, to any person
6 * obtaining a copy of this software and associated documentation
7 * files (the "Software"), to deal in the Software without
8 * restriction, including without limitation the rights to use,
9 * copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom
11 * the Software is furnished to do so, subject to the following
12 * conditions:
14 * The above copyright notice and this permission notice shall
15 * be included in all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
18 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
19 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
20 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
21 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
22 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
24 * OTHER DEALINGS IN THE SOFTWARE.
26 * -----------------------------------------------------------------------
29 #include <stdio.h>
30 #include <string.h>
31 #include <stdlib.h>
32 #include <syslinux/config.h>
34 #include "hdt-menu.h"
35 #include "hdt-cli.h"
36 #include "hdt-common.h"
38 /**
39 * cli_clear_screen - clear (erase) the entire screen
40 **/
41 static void cli_clear_screen(int argc __unused, char **argv __unused,
42 struct s_hardware *hardware __unused)
44 clear_screen();
47 /**
48 * main_show_modes - show availables modes
49 **/
50 static void main_show_modes(int argc __unused, char **argv __unused,
51 struct s_hardware *hardware __unused)
53 int i = 0;
55 reset_more_printf();
56 printf("Available modes:\n");
57 while (list_modes[i]) {
58 printf("%s ", list_modes[i]->name);
59 i++;
61 printf("\n");
64 /**
65 * cli_set_mode - set the mode of the cli, in the cli
67 * The mode number must be supplied in argv, position 0.
68 **/
69 static void cli_set_mode(int argc, char **argv, struct s_hardware *hardware)
71 cli_mode_t new_mode;
73 reset_more_printf();
74 if (argc <= 0) {
75 more_printf("Which mode?\n");
76 return;
80 * Note! argv[0] is a string representing the mode, we need the
81 * equivalent cli_mode_t to pass it to set_mode.
83 new_mode = mode_s_to_mode_t(argv[0]);
84 set_mode(new_mode, hardware);
87 /**
88 * do_exit - shared helper to exit a mode
89 **/
90 static void do_exit(int argc __unused, char **argv __unused,
91 struct s_hardware *hardware)
93 int new_mode = HDT_MODE;
95 switch (hdt_cli.mode) {
96 case HDT_MODE:
97 new_mode = EXIT_MODE;
98 break;
99 default:
100 new_mode = HDT_MODE;
101 break;
104 dprintf("CLI DEBUG: Switching from mode %d to mode %d\n", hdt_cli.mode,
105 new_mode);
106 set_mode(new_mode, hardware);
110 * show_cli_help - shared helper to show available commands
112 static void show_cli_help(int argc __unused, char **argv __unused,
113 struct s_hardware *hardware __unused)
115 int j = 0;
116 struct cli_mode_descr *current_mode;
117 struct cli_callback_descr *associated_module = NULL;
119 find_cli_mode_descr(hdt_cli.mode, &current_mode);
121 printf("Available commands are:\n");
123 /* List first default modules of the mode */
124 if (current_mode->default_modules && current_mode->default_modules->modules) {
125 while (current_mode->default_modules->modules[j].name) {
126 printf("%s ", current_mode->default_modules->modules[j].name);
127 j++;
129 printf("\n");
132 /* List secondly the show modules of the mode */
133 if (current_mode->show_modules && current_mode->show_modules->modules) {
134 printf("\nshow commands:\n");
135 j = 0;
136 while (current_mode->show_modules->modules[j].name) {
137 printf("%s ", current_mode->show_modules->modules[j].name);
138 j++;
140 printf("\n");
143 /* List thirdly the set modules of the mode */
144 if (current_mode->set_modules && current_mode->set_modules->modules) {
145 printf("\nset commands:\n");
146 j = 0;
147 while (current_mode->set_modules->modules[j].name) {
148 printf("%s ", current_mode->set_modules->modules[j].name);
149 j++;
151 printf("\n");
154 /* List finally the default modules of the hdt mode */
155 if (current_mode->mode != hdt_mode.mode &&
156 hdt_mode.default_modules && hdt_mode.default_modules->modules) {
157 j = 0;
158 while (hdt_mode.default_modules->modules[j].name) {
160 * Any default command that is present in hdt mode but
161 * not in the current mode is available. A default
162 * command can be redefined in the current mode though.
163 * This next call test this use case: if it is
164 * overwritten, do not print it again.
166 find_cli_callback_descr(hdt_mode.default_modules->modules[j].name,
167 current_mode->default_modules,
168 &associated_module);
169 if (associated_module == NULL)
170 printf("%s ", hdt_mode.default_modules->modules[j].name);
171 j++;
173 printf("\n");
176 printf("\n");
177 main_show_modes(argc, argv, hardware);
181 * show_cli_help - shared helper to show available commands
183 static void goto_menu(int argc __unused, char **argv __unused,
184 struct s_hardware *hardware)
186 char version_string[256];
187 snprintf(version_string, sizeof version_string, "%s %s (%s)",
188 PRODUCT_NAME, VERSION, CODENAME);
189 start_menu_mode(hardware, version_string);
190 return;
194 * main_show_summary - give an overview of the system
196 void main_show_summary(int argc __unused, char **argv __unused,
197 struct s_hardware *hardware)
199 detect_pci(hardware); /* pxe is detected in the pci */
200 detect_dmi(hardware);
201 cpu_detect(hardware);
202 detect_memory(hardware);
203 reset_more_printf();
204 clear_screen();
205 main_show_cpu(argc, argv, hardware);
206 if (hardware->is_dmi_valid) {
207 more_printf("System\n");
208 more_printf(" Manufacturer : %s\n", hardware->dmi.system.manufacturer);
209 more_printf(" Product Name : %s\n", hardware->dmi.system.product_name);
210 more_printf(" Serial : %s\n", hardware->dmi.system.serial);
211 more_printf("Bios\n");
212 more_printf(" Version : %s\n", hardware->dmi.bios.version);
213 more_printf(" Release : %s\n", hardware->dmi.bios.release_date);
214 more_printf("Memory Size : %lu MB (%lu KB)\n",
215 (hardware->detected_memory_size + (1 << 9)) >> 10,
216 hardware->detected_memory_size);
218 main_show_pci(argc, argv, hardware);
220 if (hardware->is_pxe_valid)
221 main_show_pxe(argc, argv, hardware);
223 main_show_kernel(argc, argv, hardware);
226 void main_show_hdt(int argc __unused, char **argv __unused,
227 struct s_hardware *hardware __unused)
229 reset_more_printf();
230 more_printf("HDT\n");
231 more_printf(" Product : %s\n", PRODUCT_NAME);
232 more_printf(" Version : %s (%s)\n", VERSION, CODENAME);
233 more_printf(" Website : %s\n", WEBSITE_URL);
234 more_printf(" Mailing List : %s\n", CONTACT);
235 more_printf(" Project Leader : %s\n", AUTHOR);
236 more_printf(" Core Developer : %s\n", CORE_DEVELOPER);
237 char *contributors[NB_CONTRIBUTORS] = CONTRIBUTORS;
238 for (int c = 0; c < NB_CONTRIBUTORS; c++) {
239 more_printf(" Contributor : %s\n", contributors[c]);
244 * do_reboot - reboot the system
246 static void do_reboot(int argc __unused, char **argv __unused,
247 struct s_hardware *hardware)
249 /* Use specific syslinux call if needed */
250 if (issyslinux())
251 return runsyslinuxcmd(hardware->reboot_label);
252 else
253 return csprint(hardware->reboot_label, 0x07);
256 /* Default hdt mode */
257 struct cli_callback_descr list_hdt_default_modules[] = {
259 .name = CLI_CLEAR,
260 .exec = cli_clear_screen,
263 .name = CLI_EXIT,
264 .exec = do_exit,
267 .name = CLI_HELP,
268 .exec = show_cli_help,
271 .name = CLI_MENU,
272 .exec = goto_menu,
275 .name = CLI_REBOOT,
276 .exec = do_reboot,
279 .name = CLI_HISTORY,
280 .exec = print_history,
283 .name = NULL,
284 .exec = NULL},
287 struct cli_callback_descr list_hdt_show_modules[] = {
289 .name = CLI_SUMMARY,
290 .exec = main_show_summary,
293 .name = CLI_PCI,
294 .exec = main_show_pci,
297 .name = CLI_DMI,
298 .exec = main_show_dmi,
301 .name = CLI_CPU,
302 .exec = main_show_cpu,
305 .name = CLI_DISK,
306 .exec = disks_summary,
309 .name = CLI_PXE,
310 .exec = main_show_pxe,
313 .name = CLI_SYSLINUX,
314 .exec = main_show_syslinux,
317 .name = CLI_KERNEL,
318 .exec = main_show_kernel,
321 .name = CLI_VESA,
322 .exec = main_show_vesa,
325 .name = CLI_HDT,
326 .exec = main_show_hdt,
329 .name = CLI_VPD,
330 .exec = main_show_vpd,
333 .name = CLI_MEMORY,
334 .exec = show_dmi_memory_modules,
337 .name = "modes",
338 .exec = main_show_modes,
341 .name = NULL,
342 .exec = NULL,
346 struct cli_callback_descr list_hdt_set_modules[] = {
348 .name = CLI_MODE,
349 .exec = cli_set_mode,
352 .name = NULL,
353 .exec = NULL,
357 struct cli_module_descr hdt_default_modules = {
358 .modules = list_hdt_default_modules,
361 struct cli_module_descr hdt_show_modules = {
362 .modules = list_hdt_show_modules,
363 .default_callback = main_show_summary,
366 struct cli_module_descr hdt_set_modules = {
367 .modules = list_hdt_set_modules,
370 struct cli_mode_descr hdt_mode = {
371 .mode = HDT_MODE,
372 .name = CLI_HDT,
373 .default_modules = &hdt_default_modules,
374 .show_modules = &hdt_show_modules,
375 .set_modules = &hdt_set_modules,