From 21a346e3f05cfe0d8e66ed098b9d2e7db146d8ae Mon Sep 17 00:00:00 2001 From: Laurent Vivier Date: Fri, 21 May 2004 10:42:54 +0000 Subject: [PATCH] Allow to read current command line --- tools/emile-set-cmdline.c | 71 +++++++++++++++++++++++++++++---------- 1 file changed, 54 insertions(+), 17 deletions(-) diff --git a/tools/emile-set-cmdline.c b/tools/emile-set-cmdline.c index 5ca9bab..4638af8 100644 --- a/tools/emile-set-cmdline.c +++ b/tools/emile-set-cmdline.c @@ -9,6 +9,7 @@ #include #include #include +#include #include "emile-first.h" @@ -17,9 +18,11 @@ static void usage(int argc, char** argv) { fprintf(stderr, "Usage: %s \n", argv[0]); + fprintf(stderr, "Usage: %s -r \n", argv[0]); fprintf(stderr, "\n Allows to set the kernel command line \n"); fprintf(stderr, " into the floppy image \n"); fprintf(stderr, " can be a file or a device (/dev/fd0)\n"); + fprintf(stderr, " with \"-r\" flag, display current command line\n"); fprintf(stderr, "\n Examples:\n"); fprintf(stderr, "\n To set root filesystem on disk 1 partition 4\n"); fprintf(stderr, "\n %s floppy.img \"root=/dev/sda4\"\n", argv[0]); @@ -32,17 +35,21 @@ static void usage(int argc, char** argv) */ } -int set_cmdline(char* image, char* cmdline) +int set_cmdline(int readonly, char* image, char* cmdline) { int fd; short buffer_size; int ret; - int len = strlen(cmdline) + 1; + int len; + + if (readonly) + fd = open(image, O_RDONLY); + else + fd = open(image, O_RDWR); - fd = open(image, O_RDWR); if (fd == -1) { - perror("Cannot open image file (rw mode)"); + perror("Cannot open image file"); return 2; } @@ -62,19 +69,48 @@ int set_cmdline(char* image, char* cmdline) return 3; } - if (len > buffer_size) + if (readonly) { - fprintf(stderr, "Command line too long\n"); - close(fd); - return 4; - } + char* buffer; - ret = write(fd, cmdline, len); - if (ret != len) + buffer = (char*)malloc(buffer_size); + if (buffer == NULL) + { + perror("Cannot malloc()"); + close(fd); + return 6; + } + + ret = read(fd, buffer, buffer_size); + if (ret != buffer_size) + { + perror("Cannot read current command line"); + free(buffer); + close(fd); + return 7; + } + printf("Current command line: \"%s\"\n", buffer); + free(buffer); + } + else { - perror("Cannot set command line"); - close(fd); - return 5; + len = strlen(cmdline) + 1; + if (len > buffer_size) + { + fprintf(stderr, "Command line too long\n"); + close(fd); + return 4; + } + + ret = write(fd, cmdline, len); + if (ret != len) + { + perror("Cannot set command line"); + close(fd); + return 5; + } + + printf("Command line sucessfully modified\n"); } close(fd); @@ -90,9 +126,10 @@ int main(int argc, char** argv) return 1; } - ret = set_cmdline(argv[1], argv[2]); - if (ret == 0) - printf("Command line sucessfully modified\n"); + if (strcmp(argv[1], "-r") == 0) + ret = set_cmdline(1, argv[2], NULL); + else + ret = set_cmdline(0, argv[1], argv[2]); return ret; }