From 6e072ae33680c4c5d31baa081e0a6d3feac22861 Mon Sep 17 00:00:00 2001 From: Olivier Blin Date: Thu, 5 Jul 2007 13:59:37 +0000 Subject: remove rescue-Flash/ (rescue-gui will be merged back with original one, and build script will be in rescue/) --- rescue-Flash/build | 32 ----- rescue-Flash/flash-rescue-gui.c | 274 ---------------------------------------- 2 files changed, 306 deletions(-) delete mode 100755 rescue-Flash/build delete mode 100644 rescue-Flash/flash-rescue-gui.c diff --git a/rescue-Flash/build b/rescue-Flash/build deleted file mode 100755 index cc6ece4d1..000000000 --- a/rescue-Flash/build +++ /dev/null @@ -1,32 +0,0 @@ -#!/bin/sh - -output_name="FLASHRESCUE" -output_file="flashrescue.iso" - -rm -f $output - -echo -n "Gerando imagem ISO de $output_name: " - -cd root - -genisoimage -o ../$output_file \ - -b i586/isolinux/isolinux.bin \ - -c i586/isolinux/boot.cat \ - -input-charset ISO-8859-1 \ - -no-emul-boot \ - -boot-load-size 4 \ - -J -R -l \ - -quiet \ - -V $output_name \ - -boot-info-table . - -if [ $? -eq 0 ]; then - output_size=$(ls -lah ../$output_file | awk '{ print $5 }') - echo "ok [$output_size]." - md5=$(md5sum ../$output_file | awk '{ print $1 }') - echo " md5: $md5" -else - echo "erro." -fi - -cd - > /dev/null diff --git a/rescue-Flash/flash-rescue-gui.c b/rescue-Flash/flash-rescue-gui.c deleted file mode 100644 index f2e17d6a3..000000000 --- a/rescue-Flash/flash-rescue-gui.c +++ /dev/null @@ -1,274 +0,0 @@ -/* - * Guillaume Cottenceau (gc@mandrakesoft.com) - * - * Copyright 2001-2007 Mandrakesoft - * - * - * This software may be freely redistributed under the terms of the GNU - * public license. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - * - */ - -#include -#include -#define _USE_BSD -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "config-stage1.h" -#include "frontend.h" -#include "tools.h" - -#ifndef LINE_MAX -#define LINE_MAX 2048 -#endif - -char * env[] = { - "PATH=/usr/bin:/bin:/sbin:/usr/sbin:/mnt/sbin:/mnt/usr/sbin:/mnt/bin:/mnt/usr/bin", - "LD_LIBRARY_PATH=/lib:/usr/lib:/mnt/lib:/mnt/usr/lib:/usr/X11R6/lib:/mnt/usr/X11R6/lib", - "HOME=/", - "TERM=linux", - "TERMINFO=/etc/terminfo", - NULL -}; - -/* pause() already exists and causes the invoking process to sleep - until a signal is received */ -static void PAUSE(void) -{ - unsigned char t; - fflush(stdout); - read(0, &t, 1); -} - -/* this is duplicated from `init.c', don't edit here */ -static inline _syscall3(int, reboot, int, magic, int, magic2, int, flag); - -#define LOOP_CLR_FD 0x4C01 - -void del_loop(char *device) -{ - int fd; - if ((fd = open(device, O_RDONLY, 0)) < 0) { - printf("del_loop open failed\n"); - return; - } - - if (ioctl(fd, LOOP_CLR_FD, 0) < 0) { - printf("del_loop ioctl failed"); - return; - } - - close(fd); -} - -struct filesystem { - char * dev; - char * name; - char * fs; - int mounted; -}; - -void unmount_filesystems(void) -{ - struct filesystem fs[500]; - int i, nb, fd, size, numfs = 0; - char *buf, *p; - - printf("unmounting filesystems...\n"); - - fd = open("/proc/mounts", O_RDONLY, 0); - if (fd == -1) { - printf("ERROR: failed to open /proc/mounts"); - sleep(2); - return; - } - - buf = (char *) malloc(LINE_MAX); - if (buf == NULL) { - printf("ERROR: not enough memory"); - sleep(2); - return; - } - bzero(buf, LINE_MAX); - size = read(fd, buf, LINE_MAX - 1); - close(fd); - - p = buf; - while (*p) { - - fs[numfs].mounted = 1; - fs[numfs].dev = p; - while (*p != ' ') - p++; - - *p++ = '\0'; - fs[numfs].name = p; - while (*p != ' ') - p++; - - *p++ = '\0'; - fs[numfs].fs = p; - while (*p != ' ') - p++; - - *p++ = '\0'; - while (*p != '\n') - p++; - p++; - if (strcmp(fs[numfs].name, "/") != 0) - /* skip if root, no need to take initrd root - in account */ - numfs++; - } - - /* multiple passes trying to umount everything */ - do { - nb = 0; - for (i = 0; i < numfs; i++) { - if (fs[i].mounted && umount(fs[i].name) == 0) { - if (strncmp(fs[i].dev + sizeof("/dev/") - 1, - "loop", sizeof("loop") - 1) == 0) - del_loop(fs[i].dev); - - printf("\t%s\n", fs[i].name); - fs[i].mounted = 0; - nb++; - } - } - } while (nb); - - for (i = nb = 0; i < numfs; i++) { - if (fs[i].mounted) { - printf("\t%s umount failed\n", fs[i].name); - if (strcmp(fs[i].fs, "ext2") == 0) - /* don't count not-ext2 umount failed */ - nb++; - } - } - - if (nb) { - printf("failed to umount some filesystems\n"); - while (1); - } -} - -void probe_that_type(void) { } - -int main(int argc __attribute__ ((unused)), char **argv __attribute__ ((unused))) -{ - enum return_type results; - - char rootpass[] = "Reset Root Password"; - char userpass[] = "Reset User Password"; - char factory[] = "Reset to Factory Defaults"; - char backup[] = "Backup User Files"; - char restore[] = "Restore User Files from Backup"; - char badblocks[] = "Test Key for Badblocks"; - char reboot_[] = "Reboot"; - - char * actions[] = { rootpass, userpass, factory, backup, restore, - badblocks, reboot_, NULL }; - char * choice; - - init_frontend("Welcome to " DISTRIB_NAME " Rescue (" - DISTRIB_VERSION ") " __DATE__ " " __TIME__); - - do { - int pid; - char * binary = NULL; - - choice = ""; - results = ask_from_list("Please choose the desired action.", - actions, &choice); - - if (ptr_begins_static_str(choice, rootpass)) { - binary = "/usr/bin/reset_rootpass"; - } - if (ptr_begins_static_str(choice, userpass)) { - binary = "/usr/bin/reset_userpass"; - } - if (ptr_begins_static_str(choice, factory)) { - binary = "/usr/bin/clear_systemloop"; - } - if (ptr_begins_static_str(choice, backup)) { - binary = "/usr/bin/backup_systemloop"; - } - if (ptr_begins_static_str(choice, restore)) { - binary = "/usr/bin/restore_systemloop"; - } - if (ptr_begins_static_str(choice, badblocks)) { - binary = "/usr/bin/test_badblocks"; - } - if (ptr_begins_static_str(choice, reboot_)) { - finish_frontend(); - sync(); sync(); - sleep(2); - unmount_filesystems(); - sync(); sync(); - printf("rebooting system\n"); - sleep(2); - reboot(0xfee1dead, 672274793, 0x01234567); - } - - if (binary) { - - int wait_status; - - suspend_to_console(); - pid = fork(); - if (pid == -1) { /* error forking */ - - printf("Can't fork()\n"); - return 33; - - } else if (pid == 0) { /* child */ - - char * child_argv[2]; - child_argv[0] = binary; - child_argv[1] = NULL; - - execve(child_argv[0], child_argv, env); - printf("Can't execute binary (%s)\n\n", binary); - PAUSE(); - - return 33; - } else { /* parent */ - - while (wait4(-1, &wait_status, 0, NULL) != pid) - ; - - printf(""); - PAUSE(); - resume_from_suspend(); - if (!WIFEXITED(wait_status) || WEXITSTATUS(wait_status) != 0) { - error_message("Program exited abnormally (return code %d).", - WEXITSTATUS(wait_status)); - if (WIFSIGNALED(wait_status)) - error_message("(received signal %d)", - WTERMSIG(wait_status)); - } - } - } - - } while (results == RETURN_OK); - - finish_frontend(); - printf("Bye.\n"); - - return 0; -} -- cgit v1.2.1