Index: apps/uninstaller-classic/SOURCES |
— | — | @@ -0,0 +1 @@ |
| 2 | +main.c
|
Index: apps/uninstaller-classic/ls.x |
— | — | @@ -0,0 +1,40 @@ |
| 2 | +ENTRY(__embios_executable_hdr)
|
| 3 | +OUTPUT_FORMAT(elf32-littlearm)
|
| 4 | +OUTPUT_ARCH(arm)
|
| 5 | +
|
| 6 | +MEMORY
|
| 7 | +{
|
| 8 | + RAM : ORIGIN = 0x08000000, LENGTH = 0x01000000
|
| 9 | +}
|
| 10 | +
|
| 11 | +SECTIONS
|
| 12 | +{
|
| 13 | + .text :
|
| 14 | + {
|
| 15 | + KEEP(.execheader*)
|
| 16 | + *(.execheader*)
|
| 17 | + *(.text*)
|
| 18 | + *(.glue_7)
|
| 19 | + *(.glue_7t)
|
| 20 | + . = ALIGN(0x4);
|
| 21 | + *(.rodata*)
|
| 22 | + . = ALIGN(0x4);
|
| 23 | + *(.data*)
|
| 24 | + . = ALIGN(0x4);
|
| 25 | + } > RAM
|
| 26 | +
|
| 27 | + .bss (NOLOAD) :
|
| 28 | + {
|
| 29 | + __bss_start = .;
|
| 30 | + *(.bss*)
|
| 31 | + *(COMMON)
|
| 32 | + __bss_end = .;
|
| 33 | + *(.stack*)
|
| 34 | + } > RAM
|
| 35 | +
|
| 36 | + /DISCARD/ :
|
| 37 | + {
|
| 38 | + *(.eh_frame)
|
| 39 | + }
|
| 40 | +
|
| 41 | +}
|
Index: apps/uninstaller-classic/main.c |
— | — | @@ -0,0 +1,106 @@ |
| 2 | +//
|
| 3 | +//
|
| 4 | +// Copyright 2010 TheSeven
|
| 5 | +//
|
| 6 | +//
|
| 7 | +// This file is part of emBIOS.
|
| 8 | +//
|
| 9 | +// emBIOS is free software: you can redistribute it and/or
|
| 10 | +// modify it under the terms of the GNU General Public License as
|
| 11 | +// published by the Free Software Foundation, either version 2 of the
|
| 12 | +// License, or (at your option) any later version.
|
| 13 | +//
|
| 14 | +// emBIOS is distributed in the hope that it will be useful,
|
| 15 | +// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
| 16 | +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
| 17 | +// See the GNU General Public License for more details.
|
| 18 | +//
|
| 19 | +// You should have received a copy of the GNU General Public License along
|
| 20 | +// with emBIOS. If not, see <http://www.gnu.org/licenses/>.
|
| 21 | +//
|
| 22 | +//
|
| 23 | +
|
| 24 | +
|
| 25 | +#include "embiosapp.h"
|
| 26 | +#include "build/version.h"
|
| 27 | +
|
| 28 | +
|
| 29 | +void main();
|
| 30 | +EMBIOS_APP_HEADER("Uninstaller thread", 0x1000, main, 127)
|
| 31 | +
|
| 32 | +
|
| 33 | +uint16_t lcdbuffer[320 * 240];
|
| 34 | +
|
| 35 | +struct wakeup eventwakeup;
|
| 36 | +volatile int button;
|
| 37 | +
|
| 38 | +uint8_t norbuf[0x100000] __attribute__((aligned(16)));
|
| 39 | +#define norbufword ((uint32_t*)norbuf)
|
| 40 | +
|
| 41 | +void handler(enum button_event eventtype, int which, int value)
|
| 42 | +{
|
| 43 | + if (eventtype == BUTTON_PRESS) button |= 1 << which;
|
| 44 | + wakeup_signal(&eventwakeup);
|
| 45 | +}
|
| 46 | +
|
| 47 | +void main(void)
|
| 48 | +{
|
| 49 | + uint32_t i, j, k;
|
| 50 | + struct progressbar_state progressbar;
|
| 51 | +
|
| 52 | + wakeup_init(&eventwakeup);
|
| 53 | + button_register_handler(handler);
|
| 54 | +
|
| 55 | + memset(lcdbuffer, 0xff, 320 * 240 * 2);
|
| 56 | + memset(norbuf, 0xff, 0x100000);
|
| 57 | + bootflash_readraw(norbuf, 0x1000, 0x1000);
|
| 58 | + if (norbufword[0] != 0x53436667)
|
| 59 | + {
|
| 60 | + cputs(1, "Boot flash contents are damaged! (No SYSCFG found)\n\nPlease ask for help.\n");
|
| 61 | + return;
|
| 62 | + }
|
| 63 | +
|
| 64 | + rendertext(&lcdbuffer[320 * 10 + 10], 0, 0xffff, "Uninstaller v" VERSION " r" VERSION_SVN, 320);
|
| 65 | + rendertext(&lcdbuffer[320 * 26 + 10], 0, 0xffff, "To restore your iPod to factory state,", 320);
|
| 66 | + rendertext(&lcdbuffer[320 * 42 + 10], 0, 0xffff, "you need to first run this program and", 320);
|
| 67 | + rendertext(&lcdbuffer[320 * 50 + 10], 0, 0xffff, "then restore your iPod using iTunes.", 320);
|
| 68 | + rendertext(&lcdbuffer[320 * 74 + 10], 0, 0xffff, "Please note that after running this", 320);
|
| 69 | + rendertext(&lcdbuffer[320 * 82 + 10], 0, 0xffff, "program, the screen of your iPod will", 320);
|
| 70 | + rendertext(&lcdbuffer[320 * 90 + 10], 0, 0xffff, "power off, and it will appear to be", 320);
|
| 71 | + rendertext(&lcdbuffer[320 * 98 + 10], 0, 0xffff, "completely dead until it is restored", 320);
|
| 72 | + rendertext(&lcdbuffer[320 * 106 + 10], 0, 0xffff, "by iTunes. Even though the screen is", 320);
|
| 73 | + rendertext(&lcdbuffer[320 * 114 + 10], 0, 0xffff, "dark, your iPod will still be powered", 320);
|
| 74 | + rendertext(&lcdbuffer[320 * 122 + 10], 0, 0xffff, "on (and you can't power it off until", 320);
|
| 75 | + rendertext(&lcdbuffer[320 * 130 + 10], 0, 0xffff, "you restore) after this step, so the", 320);
|
| 76 | + rendertext(&lcdbuffer[320 * 138 + 10], 0, 0xffff, "battery will be discharging.", 320);
|
| 77 | + rendertext(&lcdbuffer[320 * 154 + 10], 0, 0xffff, "Press skip forward to continue", 320);
|
| 78 | + rendertext(&lcdbuffer[320 * 162 + 10], 0, 0xffff, "or skip backward to cancel.", 320);
|
| 79 | + displaylcd(0, 319, 0, 239, lcdbuffer, 0);
|
| 80 | + button = 0;
|
| 81 | + while (true)
|
| 82 | + {
|
| 83 | + wakeup_wait(&eventwakeup, TIMEOUT_BLOCK);
|
| 84 | + if (button == 2) break;
|
| 85 | + else if (button == 4)
|
| 86 | + {
|
| 87 | + shutdown(false);
|
| 88 | + reset();
|
| 89 | + }
|
| 90 | + button = 0;
|
| 91 | + }
|
| 92 | + rendertext(&lcdbuffer[320 * 178 + 10], 0, 0xffff, "Preparing...", 320);
|
| 93 | + displaylcd(0, 319, 0, 239, lcdbuffer, 0);
|
| 94 | + progressbar_init(&progressbar, 1, 318, 187, 194, 0, lcd_translate_color(0, 0xcf, 0xcf, 0xcf),
|
| 95 | + lcd_translate_color(0, 0, 0, 0xcf), 0, 256);
|
| 96 | + for (i = 0; i < 256; i++)
|
| 97 | + {
|
| 98 | + bootflash_writeraw(&norbuf[i * 0x1000], i * 0x1000, 0x1000);
|
| 99 | + progressbar_setpos(&progressbar, i, false);
|
| 100 | + }
|
| 101 | + rendertext(&lcdbuffer[320 * 194 + 10], 0, 0xffff, "Will enter DFU mode in 5 seconds...", 320);
|
| 102 | + displaylcd(0, 319, 0, 239, lcdbuffer, 0);
|
| 103 | + sleep(5000000);
|
| 104 | + backlight_on(false);
|
| 105 | + shutdown(true);
|
| 106 | + reset();
|
| 107 | +}
|
Index: apps/uninstaller-classic/version.h |
— | — | @@ -0,0 +1,36 @@ |
| 2 | +//
|
| 3 | +//
|
| 4 | +// Copyright 2010 TheSeven
|
| 5 | +//
|
| 6 | +//
|
| 7 | +// This file is part of emBIOS.
|
| 8 | +//
|
| 9 | +// emBIOS is free software: you can redistribute it and/or
|
| 10 | +// modify it under the terms of the GNU General Public License as
|
| 11 | +// published by the Free Software Foundation, either version 2 of the
|
| 12 | +// License, or (at your option) any later version.
|
| 13 | +//
|
| 14 | +// emBIOS is distributed in the hope that it will be useful,
|
| 15 | +// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
| 16 | +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
| 17 | +// See the GNU General Public License for more details.
|
| 18 | +//
|
| 19 | +// You should have received a copy of the GNU General Public License along
|
| 20 | +// with emBIOS. If not, see <http://www.gnu.org/licenses/>.
|
| 21 | +//
|
| 22 | +//
|
| 23 | +
|
| 24 | +
|
| 25 | +#ifndef __VERSION_H__
|
| 26 | +#define __VERSION_H__
|
| 27 | +
|
| 28 | +
|
| 29 | +#define VERSION "0.0.1"
|
| 30 | +#define VERSION_MAJOR 0
|
| 31 | +#define VERSION_MINOR 0
|
| 32 | +#define VERSION_PATCH 1
|
| 33 | +#define VERSION_SVN "$REVISION$"
|
| 34 | +#define VERSION_SVN_INT $REVISIONINT$
|
| 35 | +
|
| 36 | +
|
| 37 | +#endif |
\ No newline at end of file |
Index: apps/uninstaller-classic/Makefile |
— | — | @@ -0,0 +1,101 @@ |
| 2 | +NAME := uninstaller-classic
|
| 3 | +
|
| 4 | +EMBIOSDIR ?= ../../embios/trunk/
|
| 5 | +
|
| 6 | +CROSS ?= arm-none-eabi-
|
| 7 | +CC := $(CROSS)gcc
|
| 8 | +AS := $(CROSS)as
|
| 9 | +LD := $(CROSS)ld
|
| 10 | +OBJCOPY := $(CROSS)objcopy
|
| 11 | +UCLPACK := ucl2e10singleblk
|
| 12 | +
|
| 13 | +CFLAGS += -Os -fno-pie -fno-stack-protector -fomit-frame-pointer -I. -I$(EMBIOSDIR)/export -ffunction-sections -fdata-sections -mcpu=arm940t
|
| 14 | +LDFLAGS += "$(shell $(CC) -print-libgcc-file-name)" --gc-sections
|
| 15 | +
|
| 16 | +preprocess = $(shell $(CC) $(PPCFLAGS) $(2) -E -P -x c $(1) | grep -v "^\#")
|
| 17 | +preprocesspaths = $(shell $(CC) $(PPCFLAGS) $(2) -E -P -x c $(1) | grep -v "^\#" | sed -e "s:^..*:$(dir $(1))&:")
|
| 18 | +
|
| 19 | +REVISION := $(shell svnversion .)
|
| 20 | +REVISIONINT := $(shell echo $(REVISION) | sed -e "s/[^0-9].*$$//")
|
| 21 | +
|
| 22 | +HELPERS := build/__embios_armhelpers.o
|
| 23 | +
|
| 24 | +SRC := $(call preprocesspaths,SOURCES,-I. -I..)
|
| 25 | +OBJ := $(SRC:%.c=build/%.o)
|
| 26 | +OBJ := $(OBJ:%.S=build/%.o) $(HELPERS)
|
| 27 | +
|
| 28 | +all: $(NAME)
|
| 29 | +
|
| 30 | +-include $(OBJ:%=%.dep)
|
| 31 | +
|
| 32 | +$(NAME): build/$(NAME).embiosapp.ucl
|
| 33 | +
|
| 34 | +build/$(NAME).embiosapp.ucl: build/$(NAME).embiosapp
|
| 35 | + @echo [UCL] $<
|
| 36 | + @$(UCLPACK) $^ $@
|
| 37 | +
|
| 38 | +build/$(NAME).embiosapp: build/$(NAME).elf
|
| 39 | + @echo [OC] $<
|
| 40 | + @$(OBJCOPY) -O binary $^ $@
|
| 41 | +
|
| 42 | +build/$(NAME).elf: ls.x $(OBJ)
|
| 43 | + @echo [LD] $@
|
| 44 | + @$(LD) $(LDFLAGS) -o $@ -T ls.x $(OBJ)
|
| 45 | +
|
| 46 | +build/%.o: %.c build/version.h
|
| 47 | + @echo [CC] $<
|
| 48 | +ifeq ($(shell uname),WindowsNT)
|
| 49 | + @-if not exist $(subst /,\,$(dir $@)) md $(subst /,\,$(dir $@))
|
| 50 | +else
|
| 51 | + @-mkdir -p $(dir $@)
|
| 52 | +endif
|
| 53 | + @$(CC) -c $(CFLAGS) -o $@ $<
|
| 54 | + @$(CC) -MM $(CFLAGS) $< > $@.dep.tmp
|
| 55 | + @sed -e "s|.*:|$@:|" < $@.dep.tmp > $@.dep
|
| 56 | +ifeq ($(shell uname),WindowsNT)
|
| 57 | + @sed -e "s/.*://" -e "s/\\$$//" < $@.dep.tmp | fmt -1 | sed -e "s/^ *//" -e "s/$$/:/" >> $@.dep
|
| 58 | +else
|
| 59 | + @sed -e 's/.*://' -e 's/\\$$//' < $@.dep.tmp | fmt -1 | sed -e 's/^ *//' -e 's/$$/:/' >> $@.dep
|
| 60 | +endif
|
| 61 | + @rm -f $@.dep.tmp
|
| 62 | +
|
| 63 | +build/%.o: %.S build/version.h
|
| 64 | + @echo [CC] $<
|
| 65 | +ifeq ($(shell uname),WindowsNT)
|
| 66 | + @-if not exist $(subst /,\,$(dir $@)) md $(subst /,\,$(dir $@))
|
| 67 | +else
|
| 68 | + @-mkdir -p $(dir $@)
|
| 69 | +endif
|
| 70 | + @$(CC) -c $(CFLAGS) -o $@ $<
|
| 71 | + @$(CC) -MM $(CFLAGS) $< > $@.dep.tmp
|
| 72 | + @sed -e "s|.*:|$@:|" < $@.dep.tmp > $@.dep
|
| 73 | +ifeq ($(shell uname),WindowsNT)
|
| 74 | + @sed -e "s/.*://" -e "s/\\$$//" < $@.dep.tmp | fmt -1 | sed -e "s/^ *//" -e "s/$$/:/" >> $@.dep
|
| 75 | +else
|
| 76 | + @sed -e 's/.*://' -e 's/\\$$//' < $@.dep.tmp | fmt -1 | sed -e 's/^ *//' -e 's/$$/:/' >> $@.dep
|
| 77 | +endif
|
| 78 | + @rm -f $@.dep.tmp
|
| 79 | +
|
| 80 | +build/__embios_%.o: $(EMBIOSDIR)/export/%.S
|
| 81 | + @echo [CC] $<
|
| 82 | +ifeq ($(shell uname),WindowsNT)
|
| 83 | + @-if not exist $(subst /,\,$(dir $@)) md $(subst /,\,$(dir $@))
|
| 84 | +else
|
| 85 | + @-mkdir -p $(dir $@)
|
| 86 | +endif
|
| 87 | + @$(CC) -c $(CFLAGS) -o $@ $<
|
| 88 | +
|
| 89 | +build/version.h: version.h .svn/entries
|
| 90 | + @echo [PP] $<
|
| 91 | +ifeq ($(shell uname),WindowsNT)
|
| 92 | + @-if not exist build md build
|
| 93 | + @sed -e "s/\$$REVISION\$$/$(REVISION)/" -e "s/\$$REVISIONINT\$$/$(REVISIONINT)/" < $< > $@
|
| 94 | +else
|
| 95 | + @-mkdir -p build
|
| 96 | + @sed -e 's/\$$REVISION\$$/$(REVISION)/' -e 's/\$$REVISIONINT\$$/$(REVISIONINT)/' < $< > $@
|
| 97 | +endif
|
| 98 | +
|
| 99 | +clean:
|
| 100 | + @rm -rf build
|
| 101 | +
|
| 102 | +.PHONY: all clean $(NAME)
|
Index: apps/uninstaller-classic |
Property changes on: apps/uninstaller-classic |
___________________________________________________________________ |
Added: svn:ignore |
## -0,0 +1 ## |
| 103 | +build |
Index: apps/installer-classic/flashfiles/iloader.conf |
— | — | @@ -18,18 +18,12 @@ |
19 | 19 | menu(nothememenu, 0, 0xffffffff, 0xfffffffe, 0xffffffff, 0xfffffffe, 0)
|
20 | 20 |
|
21 | 21 | nothememenu:
|
22 | | - .menuentry(" Enter disk mode \0", 16, 64, 0x0000, 0xffff, 0xffff, 0x001f, diskmode)
|
23 | | - .menuentry(" Run UMSboot \0", 16, 72, 0x0000, 0xffff, 0xffff, 0x001f, umsboot)
|
24 | | - .menuentry(" Quit iLoader \0", 16, 80, 0x0000, 0xffff, 0xffff, 0x001f, quit)
|
25 | | - .menuentry(" Power off \0", 16, 88, 0x0000, 0xffff, 0xffff, 0x001f, off)
|
| 22 | + .menuentry(" Uninstall iLoader \0", 16, 56, 0x0000, 0xffff, 0xffff, 0x001f, uninstall)
|
| 23 | + .menuentry(" Run UMSboot \0", 16, 64, 0x0000, 0xffff, 0xffff, 0x001f, umsboot)
|
| 24 | + .menuentry(" Quit iLoader \0", 16, 72, 0x0000, 0xffff, 0xffff, 0x001f, quit)
|
| 25 | + .menuentry(" Power off \0", 16, 80, 0x0000, 0xffff, 0xffff, 0x001f, off)
|
26 | 26 | .word(0)
|
27 | 27 |
|
28 | | -diskmode:
|
29 | | - readflash(0x08000000, "diskmode")
|
30 | | - sleep(200000)
|
31 | | - backlight(1, 55, 10)
|
32 | | - exec(0x08000000)
|
33 | | -
|
34 | 28 | umsboot:
|
35 | 29 | readflash(0x08000000, "umsboot ")
|
36 | 30 | backlight(1, 55, 10)
|
— | — | @@ -38,5 +32,9 @@ |
39 | 33 | quit:
|
40 | 34 | terminate()
|
41 | 35 |
|
| 36 | +uninstall:
|
| 37 | + readflash(0x08000000, "uninst ")
|
| 38 | + execembiosapp(0x08000000, 1)
|
| 39 | +
|
42 | 40 | off:
|
43 | 41 | poweroff()
|
Index: apps/installer-classic/tools/geninstaller.py |
— | — | @@ -32,10 +32,12 @@ |
33 | 33 | flashfiles = [("ildrcfg ", 2, 0, 0, "iloader.cfg.ucl"), \
|
34 | 34 | ("iloader ", 2, 0, 0, "iloader.embiosapp.ucl"), \
|
35 | 35 | ("umsboot ", 2, 0, 0, "umsboot-ipodclassic.ucl"), \
|
| 36 | + ("uninst ", 2, 0, 0, "uninstaller-classic.embiosapp.ucl"), \
|
36 | 37 | ("embiosldr", 12, 8, 0, "embiosldr-ipodclassic.bin"), \
|
37 | 38 | ("embios ", 2, 0, 0, "embios-ipodclassic.ucl")]
|
38 | 39 |
|
39 | | -firstinstfiles = [(2, "/iLoader/iLoader.cfg", "../iloader/themes/ipodclassic-default/iLoader/iloader.cfg", 1), \
|
| 40 | +firstinstfiles = [(1, "/iLoader", 1), \
|
| 41 | + (2, "/iLoader/iLoader.cfg", "../iloader/themes/ipodclassic-default/iLoader/iloader.cfg", 1), \
|
40 | 42 | (2, "/iLoader/theme.ucl", "../iloader/themes/ipodclassic-default/iLoader/theme.ucl", 2)]
|
41 | 43 |
|
42 | 44 | commonfiles = [(2, "/iLoader/NORFlash.bak", -2, 10)]
|
— | — | @@ -54,13 +56,13 @@ |
55 | 57 | file = open(sys.argv[1], "rb")
|
56 | 58 | installer = file.read()
|
57 | 59 | file.close()
|
58 | | -installer = installer.ljust((len(installer) + 3) & ~3)
|
| 60 | +installer = installer.ljust((len(installer) + 3) & ~3, '\0')
|
59 | 61 |
|
60 | 62 | for f in bitmaps:
|
61 | 63 | file = open("build/" + f, "rb")
|
62 | 64 | fdata = file.read()
|
63 | 65 | file.close()
|
64 | | - fdata = fdata.ljust((len(fdata) + 3) & ~3)
|
| 66 | + fdata = fdata.ljust((len(fdata) + 3) & ~3, '\0')
|
65 | 67 | installer = installer + struct.pack("<I", len(fdata)) + fdata
|
66 | 68 |
|
67 | 69 | statusfirst = 0
|
— | — | @@ -91,7 +93,7 @@ |
92 | 94 | fdata = file.read()
|
93 | 95 | file.close()
|
94 | 96 | flash = flash + struct.pack("<II", scriptsize + len(filedata), len(fdata))
|
95 | | - filedata = filedata + fdata.ljust((len(fdata) + 15) & ~15)
|
| 97 | + filedata = filedata + fdata.ljust((len(fdata) + 15) & ~15, '\0')
|
96 | 98 | if (f[1] & 4) == 0: flash = flash + f[0]
|
97 | 99 |
|
98 | 100 | firstinstall = ""
|
— | — | @@ -98,7 +100,7 @@ |
99 | 101 | for f in firstinstfiles:
|
100 | 102 | size = 0
|
101 | 103 | nameptr = scriptsize + len(filedata)
|
102 | | - filedata = filedata + (f[1] + "\0").ljust((len(f[1]) + 16) & ~15)
|
| 104 | + filedata = filedata + (f[1] + "\0").ljust((len(f[1]) + 16) & ~15, '\0')
|
103 | 105 | if f[0] == 1:
|
104 | 106 | firstinstall = firstinstall + struct.pack("<III", f[0], nameptr, f[2])
|
105 | 107 | statusfirst = statusfirst + f[2]
|
— | — | @@ -109,7 +111,7 @@ |
110 | 112 | file.close()
|
111 | 113 | ptr = scriptsize + len(filedata)
|
112 | 114 | size = len(fdata)
|
113 | | - filedata = filedata + fdata.ljust((len(fdata) + 15) & ~15)
|
| 115 | + filedata = filedata + fdata.ljust((len(fdata) + 15) & ~15, '\0')
|
114 | 116 | else:
|
115 | 117 | ptr = f[2]
|
116 | 118 | firstinstall = firstinstall + struct.pack("<IIiII", f[0], nameptr, ptr, size, f[3])
|
— | — | @@ -119,7 +121,7 @@ |
120 | 122 | for f in commonfiles:
|
121 | 123 | size = 0
|
122 | 124 | nameptr = scriptsize + len(filedata)
|
123 | | - filedata = filedata + (f[1] + "\0").ljust((len(f[1]) + 16) & ~15)
|
| 125 | + filedata = filedata + (f[1] + "\0").ljust((len(f[1]) + 16) & ~15, '\0')
|
124 | 126 | if f[0] == 1:
|
125 | 127 | common = common + struct.pack("<III", f[0], nameptr, f[2])
|
126 | 128 | statuscommon = statuscommon + f[2]
|
— | — | @@ -130,7 +132,7 @@ |
131 | 133 | file.close()
|
132 | 134 | ptr = scriptsize + len(filedata)
|
133 | 135 | size = len(fdata)
|
134 | | - filedata = filedata + fdata.ljust((len(fdata) + 15) & ~15)
|
| 136 | + filedata = filedata + fdata.ljust((len(fdata) + 15) & ~15, '\0')
|
135 | 137 | else:
|
136 | 138 | ptr = f[2]
|
137 | 139 | common = common + struct.pack("<IIiII", f[0], nameptr, ptr, size, f[3])
|
— | — | @@ -140,5 +142,5 @@ |
141 | 143 | statusfirst, statusfirst + statuscommon) \
|
142 | 144 | + firstinstall + common + struct.pack("<I", 0)
|
143 | 145 | file = open(sys.argv[2], "wb")
|
144 | | -file.write(installer + script.ljust(scriptsize) + filedata)
|
| 146 | +file.write(installer + script.ljust(scriptsize, '\0') + filedata)
|
145 | 147 | file.close()
|
Index: apps/installer-classic/oobe/warning.bmp |
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Index: apps/installer-classic/oobe/oobe.psd |
Cannot display: file marked as a binary type. |
svn:mime-type = application/octet-stream |
Index: apps/installer-classic/Makefile |
— | — | @@ -2,12 +2,13 @@ |
3 | 3 |
|
4 | 4 | EMBIOSDIR ?= ../../embios/trunk/
|
5 | 5 | ILOADERDIR ?= ../iloader/
|
| 6 | +UNINSTDIR ?= ../uninstaller-classic/
|
6 | 7 | UMSBOOTDIR ?= ../../umsboot/
|
7 | 8 | TOOLSDIR ?= ../../tools/
|
8 | 9 |
|
9 | 10 | BITMAPS = build/sidepane.ucl build/warning.ucl build/installing.ucl build/formatting.ucl build/copying.ucl build/flashing.ucl
|
10 | 11 |
|
11 | | -FLASHFILES = flashfiles/iloader.cfg.ucl flashfiles/iloader.embiosapp.ucl \
|
| 12 | +FLASHFILES = flashfiles/uninstaller-classic.embiosapp.ucl flashfiles/iloader.cfg.ucl flashfiles/iloader.embiosapp.ucl \
|
12 | 13 | flashfiles/embiosldr-ipodclassic.bin flashfiles/embios-ipodclassic.ucl flashfiles/umsboot-ipodclassic.ucl
|
13 | 14 |
|
14 | 15 | CROSS ?= arm-none-eabi-
|
— | — | @@ -145,6 +146,12 @@ |
146 | 147 | flashfiles: $(FLASHFILES)
|
147 | 148 | @touch flashfiles.built
|
148 | 149 |
|
| 150 | +$(UNINSTDIR)/build/uninstaller-classic.embiosapp.ucl: uninstaller-classic
|
| 151 | +
|
| 152 | +flashfiles/uninstaller-classic.embiosapp.ucl: $(UNINSTDIR)/build/uninstaller-classic.embiosapp.ucl uninstaller-classic
|
| 153 | + @echo [CP] $@
|
| 154 | + @cp $< $@
|
| 155 | +
|
149 | 156 | $(UMSBOOTDIR)/build/ipodclassic/umsboot-ipodclassic.ucl: umsboot
|
150 | 157 |
|
151 | 158 | flashfiles/umsboot-ipodclassic.ucl: $(UMSBOOTDIR)/build/ipodclassic/umsboot-ipodclassic.ucl umsboot
|
— | — | @@ -191,6 +198,9 @@ |
192 | 199 | iloader:
|
193 | 200 | @make -C $(ILOADERDIR)
|
194 | 201 |
|
| 202 | +uninstaller-classic:
|
| 203 | + @make -C $(UNINSTDIR)
|
| 204 | +
|
195 | 205 | $(UMSBOOTDIR)/build/ipodclassic/umsboot.bin: umsboot
|
196 | 206 |
|
197 | 207 | umsboot:
|
— | — | @@ -199,4 +209,4 @@ |
200 | 210 | clean:
|
201 | 211 | @rm -rf build
|
202 | 212 |
|
203 | | -.PHONY: all clean iloader embios embiosldr-ipodclassic umsboot libucl flashfiles $(NAME)
|
| 213 | +.PHONY: all clean uninstaller-classic iloader embios embiosldr-ipodclassic umsboot libucl flashfiles $(NAME)
|