From: Vladimir 'phcoder' Serbinenko Date: Sat, 22 May 2010 18:28:09 +0000 (+0200) Subject: merge mainline into cmostest X-Git-Tag: 1.99~878^2~1 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=c49abfdd24c97103b3e3acec6679ddba7f557276;p=thirdparty%2Fgrub.git merge mainline into cmostest --- c49abfdd24c97103b3e3acec6679ddba7f557276 diff --cc commands/i386/cmostest.c index 7171766cd,000000000..36c35e6c4 mode 100644,000000..100644 --- a/commands/i386/cmostest.c +++ b/commands/i386/cmostest.c @@@ -1,59 -1,0 +1,59 @@@ +/* + * GRUB -- GRand Unified Bootloader + * Copyright (C) 2009 Free Software Foundation, Inc. + * + * GRUB is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * GRUB is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GRUB. If not, see . + */ + +#include +#include +#include - #include ++#include + +static grub_err_t +grub_cmd_cmostest (struct grub_command *cmd __attribute__ ((unused)), + int argc, char *argv[]) +{ + int byte, bit; + char *rest; + + if (argc != 1) + return grub_error (GRUB_ERR_BAD_ARGUMENT, "Address required."); + + byte = grub_strtoul (argv[0], &rest, 0); + if (*rest != ':') + return grub_error (GRUB_ERR_BAD_ARGUMENT, "Address required."); + + bit = grub_strtoul (rest + 1, 0, 0); + + if (grub_cmos_read (byte) & (1 << bit)) + return GRUB_ERR_NONE; + + return grub_error (GRUB_ERR_TEST_FAILURE, "false"); +} + +static grub_command_t cmd; + + +GRUB_MOD_INIT(cmostest) +{ + cmd = grub_register_command ("cmostest", grub_cmd_cmostest, + "cmostest BYTE:BIT", + "Test bit at BYTE:BIT in CMOS."); +} + +GRUB_MOD_FINI(cmostest) +{ + grub_unregister_command (cmd); +} diff --cc conf/i386-coreboot.rmk index b49af84ce,b8713a7b0..f6a375624 --- a/conf/i386-coreboot.rmk +++ b/conf/i386-coreboot.rmk @@@ -187,26 -68,5 +68,11 @@@ datetime_mod_SOURCES = lib/cmos_datetim datetime_mod_CFLAGS = $(COMMON_CFLAGS) datetime_mod_LDFLAGS = $(COMMON_LDFLAGS) - # For date.mod - date_mod_SOURCES = commands/date.c - date_mod_CFLAGS = $(COMMON_CFLAGS) - date_mod_LDFLAGS = $(COMMON_LDFLAGS) - - # For datehook.mod - datehook_mod_SOURCES = hook/datehook.c - datehook_mod_CFLAGS = $(COMMON_CFLAGS) - datehook_mod_LDFLAGS = $(COMMON_LDFLAGS) - - # For lsmmap.mod - lsmmap_mod_SOURCES = commands/lsmmap.c - lsmmap_mod_CFLAGS = $(COMMON_CFLAGS) - lsmmap_mod_LDFLAGS = $(COMMON_LDFLAGS) - +# For cmostest.mod +pkglib_MODULES += cmostest.mod +cmostest_mod_SOURCES = commands/i386/cmostest.c +cmostest_mod_CFLAGS = $(COMMON_CFLAGS) +cmostest_mod_LDFLAGS = $(COMMON_LDFLAGS) + include $(srcdir)/conf/i386.mk include $(srcdir)/conf/common.mk