* [PATCH] sleep.mod
@ 2008-02-08 16:15 Robert Millan
2008-02-09 10:56 ` Robert Millan
2008-02-17 14:18 ` Alexandre Boeglin
0 siblings, 2 replies; 6+ messages in thread
From: Robert Millan @ 2008-02-08 16:15 UTC (permalink / raw)
To: grub-devel
[-- Attachment #1: Type: text/plain, Size: 164 bytes --]
A sleep command.
--
Robert Millan
<GPLv2> I know my rights; I want my phone call!
<DRM> What use is a phone call… if you are unable to speak?
(as seen on /.)
[-- Attachment #2: sleep.diff --]
[-- Type: text/x-diff, Size: 3794 bytes --]
diff -x configure -x config.h.in -x CVS -x '*~' -x '*.mk' -urp -N ../grub2/commands/sleep.c ./commands/sleep.c
--- ../grub2/commands/sleep.c 1970-01-01 01:00:00.000000000 +0100
+++ ./commands/sleep.c 2008-02-08 17:01:51.000000000 +0100
@@ -0,0 +1,110 @@
+/* sleep.c - Command to wait a specified number of seconds. */
+/*
+ * GRUB -- GRand Unified Bootloader
+ * Copyright (C) 2006,2007,2008 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 <http://www.gnu.org/licenses/>.
+ */
+
+#include <grub/dl.h>
+#include <grub/term.h>
+#include <grub/types.h>
+#include <grub/misc.h>
+#include <grub/normal.h>
+#include <grub/machine/time.h>
+
+static const struct grub_arg_option options[] =
+ {
+ {"verbose", 'v', 0, "verbose countdown", 0, 0},
+ {"interruptible", 'i', 0, "interruptible with ESC", 0, 0},
+ {0, 0, 0, 0, 0, 0}
+ };
+
+static grub_uint8_t x, y;
+
+static void
+do_print (int n)
+{
+ grub_gotoxy (x, y);
+ /* NOTE: Do not remove the trailing space characters.
+ They are required to clear the line. */
+ grub_printf ("%d ", n);
+}
+
+/* Based on grub_millisleep() from kern/misc.c. */
+static int
+grub_interruptible_millisleep (grub_uint32_t ms)
+{
+ grub_uint32_t end_at;
+
+ end_at = grub_get_rtc () + grub_div_roundup (ms * GRUB_TICKS_PER_SECOND, 1000);
+
+ while (grub_get_rtc () < end_at)
+ if (GRUB_TERM_ASCII_CHAR (grub_checkkey ()) == GRUB_TERM_ESC)
+ return 1;
+
+ return 0;
+}
+
+static grub_err_t
+grub_cmd_sleep (struct grub_arg_list *state, int argc, char **args)
+{
+ grub_uint16_t xy;
+ int n;
+
+ if (argc != 1)
+ return grub_error (GRUB_ERR_BAD_ARGUMENT, "missing operand");
+
+ n = grub_strtoul (args[0], 0, 10);
+
+ if (n == 0)
+ {
+ /* Either `0' or broken input. */
+ return 0;
+ }
+
+ xy = grub_getxy ();
+ x = xy >> 8;
+ y = xy & 0xff;
+
+ for (; n; n--)
+ {
+ if (state[0].set)
+ do_print (n);
+
+ if (state[1].set)
+ {
+ if (grub_interruptible_millisleep (1000))
+ return 1;
+ }
+ else
+ grub_millisleep (1000);
+ }
+ if (state[0].set)
+ do_print (0);
+
+ return 0;
+}
+
+\f
+GRUB_MOD_INIT(sleep)
+{
+ grub_register_command ("sleep", grub_cmd_sleep, GRUB_COMMAND_FLAG_BOTH,
+ "sleep NUMBER_OF_SECONDS", "Wait for a specified number of seconds", options);
+}
+
+GRUB_MOD_FINI(sleep)
+{
+ grub_unregister_command ("sleep");
+}
diff -x configure -x config.h.in -x CVS -x '*~' -x '*.mk' -urp -N ../grub2/conf/common.rmk ./conf/common.rmk
--- ../grub2/conf/common.rmk 2008-02-06 17:21:45.000000000 +0100
+++ ./conf/common.rmk 2008-02-08 16:08:26.000000000 +0100
@@ -265,7 +265,7 @@ pkglib_MODULES += hello.mod boot.mod ter
cmp.mod cat.mod help.mod font.mod search.mod \
loopback.mod configfile.mod echo.mod \
terminfo.mod test.mod blocklist.mod hexdump.mod \
- read.mod
+ read.mod sleep.mod
# For hello.mod.
hello_mod_SOURCES = hello/hello.c
@@ -364,3 +364,8 @@ gzio_mod_LDFLAGS = $(COMMON_LDFLAGS)
read_mod_SOURCES = commands/read.c
read_mod_CFLAGS = $(COMMON_CFLAGS)
read_mod_LDFLAGS = $(COMMON_LDFLAGS)
+
+# For sleep.mod.
+sleep_mod_SOURCES = commands/sleep.c
+sleep_mod_CFLAGS = $(COMMON_CFLAGS)
+sleep_mod_LDFLAGS = $(COMMON_LDFLAGS)
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] sleep.mod
2008-02-08 16:15 [PATCH] sleep.mod Robert Millan
@ 2008-02-09 10:56 ` Robert Millan
2008-02-17 14:18 ` Alexandre Boeglin
1 sibling, 0 replies; 6+ messages in thread
From: Robert Millan @ 2008-02-09 10:56 UTC (permalink / raw)
To: grub-devel
Committed.
--
Robert Millan
<GPLv2> I know my rights; I want my phone call!
<DRM> What use is a phone call… if you are unable to speak?
(as seen on /.)
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] sleep.mod
2008-02-08 16:15 [PATCH] sleep.mod Robert Millan
2008-02-09 10:56 ` Robert Millan
@ 2008-02-17 14:18 ` Alexandre Boeglin
2008-02-20 21:20 ` Yoshinori K. Okuji
1 sibling, 1 reply; 6+ messages in thread
From: Alexandre Boeglin @ 2008-02-17 14:18 UTC (permalink / raw)
To: The development of GRUB 2
Le ven 08 fév 2008 à 17:15:35 +0100, Robert Millan a écrit :
> +static int
> +grub_interruptible_millisleep (grub_uint32_t ms)
> +{
> + grub_uint32_t end_at;
> +
> + end_at = grub_get_rtc () + grub_div_roundup (ms * GRUB_TICKS_PER_SECOND, 1000);
> +
> + while (grub_get_rtc () < end_at)
> + if (GRUB_TERM_ASCII_CHAR (grub_checkkey ()) == GRUB_TERM_ESC)
> + return 1;
> +
> + return 0;
> +}
I have a few issues with this on a EFI machine:
- if I press any other key but ESC, the sleep command is not interruptible
anymore
- the keys I press are read when the command returns
Does this happen on other machines as well ?
Alex
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] sleep.mod
2008-02-17 14:18 ` Alexandre Boeglin
@ 2008-02-20 21:20 ` Yoshinori K. Okuji
2008-02-24 15:25 ` Robert Millan
0 siblings, 1 reply; 6+ messages in thread
From: Yoshinori K. Okuji @ 2008-02-20 21:20 UTC (permalink / raw)
To: The development of GRUB 2
On Sunday 17 February 2008 15:18, Alexandre Boeglin wrote:
> I have a few issues with this on a EFI machine:
> - if I press any other key but ESC, the sleep command is not interruptible
> anymore
> - the keys I press are read when the command returns
>
> Does this happen on other machines as well ?
It must be consistent with all architectures, since the terminal API assumes a
FIFO buffer for key inputs.
Anyway, I don't like the current implementation of sleep. Robert, are you
going to change it according to our discussion?
Okuji
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] sleep.mod
2008-02-20 21:20 ` Yoshinori K. Okuji
@ 2008-02-24 15:25 ` Robert Millan
2008-02-26 22:33 ` Yoshinori K. Okuji
0 siblings, 1 reply; 6+ messages in thread
From: Robert Millan @ 2008-02-24 15:25 UTC (permalink / raw)
To: The development of GRUB 2
On Wed, Feb 20, 2008 at 10:20:23PM +0100, Yoshinori K. Okuji wrote:
>
> Anyway, I don't like the current implementation of sleep. Robert, are you
> going to change it according to our discussion?
Sorry, I was going to do that, then my time completely disappeared with other
stuff. Please don't interpret this as refusal to change it.
I'll try to have a look later (if noone beats me to it).
--
Robert Millan
<GPLv2> I know my rights; I want my phone call!
<DRM> What use is a phone call… if you are unable to speak?
(as seen on /.)
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] sleep.mod
2008-02-24 15:25 ` Robert Millan
@ 2008-02-26 22:33 ` Yoshinori K. Okuji
0 siblings, 0 replies; 6+ messages in thread
From: Yoshinori K. Okuji @ 2008-02-26 22:33 UTC (permalink / raw)
To: The development of GRUB 2
On Sunday 24 February 2008 16:25, Robert Millan wrote:
> On Wed, Feb 20, 2008 at 10:20:23PM +0100, Yoshinori K. Okuji wrote:
> > Anyway, I don't like the current implementation of sleep. Robert, are you
> > going to change it according to our discussion?
>
> Sorry, I was going to do that, then my time completely disappeared with
> other stuff. Please don't interpret this as refusal to change it.
No problem. I was just wondering your intention.
> I'll try to have a look later (if noone beats me to it).
Thanks.
Okuji
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2008-02-26 22:33 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-02-08 16:15 [PATCH] sleep.mod Robert Millan
2008-02-09 10:56 ` Robert Millan
2008-02-17 14:18 ` Alexandre Boeglin
2008-02-20 21:20 ` Yoshinori K. Okuji
2008-02-24 15:25 ` Robert Millan
2008-02-26 22:33 ` Yoshinori K. Okuji
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.