mirror of
https://github.com/wiidev/usbloadergx.git
synced 2024-11-08 04:25:07 +01:00
*Added support for using USB port 1 (ONLY ON HERMES CIOS)
*Added support for using both USB ports at once (ONLY ON HERMES CIOS) Big thanks to rodries for writing the necessary ehcmodules! NOTE: You can change port of USB device in the Loader Settings. The loader currently does not support loading configs off port 1 (only from port 0) If you select to use both usb ports the loader will switch between ports automatically, on demand. It is not possible to use both ports at once currently. Right now the wiilight blinks each time it switches the port. I will talk to rodries and see if we can disable it. Using the "both ports" option only makes sense in combination with "Multiple Partitions" option. In that case all games on all partitions from BOTH HDDs will be loaded. I think I don't have to say that switching between ports and loading all games is slower than normal mode with one port only in use. You might wanna just set one port and switch yourself when you need to. Well the option for both ports (automatic switching) is there for the lazy ones who don't like to hit the settings button ;).
This commit is contained in:
parent
f43bdc65d3
commit
d625c5adfc
@ -2,8 +2,8 @@
|
||||
<app version="1">
|
||||
<name> USB Loader GX</name>
|
||||
<coder>USB Loader GX Team</coder>
|
||||
<version>2.0 r1065</version>
|
||||
<release_date>201102051739</release_date>
|
||||
<version>2.0 r1066</version>
|
||||
<release_date>201102052106</release_date>
|
||||
<no_ios_reload/>
|
||||
<short_description>Loads games from USB-devices</short_description>
|
||||
<long_description>USB Loader GX is a libwiigui based USB iso loader with a wii-like GUI. You can install games to your HDDs and boot them with shorter loading times.
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: David Jelinek (djelinek@hotmail.com) e->e,r->r,u->u, c->c \n"
|
||||
"Language-Team: r1056 - last version on http://djelinek.sweb.cz/_USBLoderGX/czech.lang \n"
|
||||
@ -243,6 +243,9 @@ msgstr "Spustit?"
|
||||
msgid "Both"
|
||||
msgstr "Oboje"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Nelze naformátovat"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB zarízení nenalezeno"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX je zabezpecen"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Odinstalace"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: Fox888[dk]\n"
|
||||
"Language-Team: [dk]\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Genstart?"
|
||||
msgid "Both"
|
||||
msgstr "Begge"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Kan ikke formateres"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB-enhed ikke fundet"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX er beskyttet"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Afinstallér"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2011-02-04 13:06+0100\n"
|
||||
"Last-Translator: glowy\n"
|
||||
"Language-Team: tj_cool, glowy\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Start?"
|
||||
msgid "Both"
|
||||
msgstr "Beide"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Kan niet geformatteerd worden"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB Apparaat niet gevonden"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX is vergrendeld"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Verwijderen"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: \n"
|
||||
"Language-Team: \n"
|
||||
@ -243,6 +243,9 @@ msgstr ""
|
||||
msgid "Both"
|
||||
msgstr ""
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr ""
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr ""
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr ""
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: c64rmx\n"
|
||||
"Language-Team: \n"
|
||||
@ -243,6 +243,9 @@ msgstr "Boottaa?"
|
||||
msgid "Both"
|
||||
msgstr "Molemmat"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Ei voida formatoida"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB-laitetta ei löytynyt"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX on suojattu."
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Poista"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: Cyan\n"
|
||||
"Language-Team: Badablek, Amour, ikya & Kin8\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Lancer ?"
|
||||
msgid "Both"
|
||||
msgstr "Les deux"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Formatage impossible"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "Périphérique USB introuvable"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX est verrouillé"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Désinstaller"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2010-07-03 17:35-0800\n"
|
||||
"Last-Translator: TheRealVisitor\n"
|
||||
"Language-Team: Bertilax, Snoozer, wishmasterf, ZEN.13, TheRealVisitor\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Kanal starten?"
|
||||
msgid "Both"
|
||||
msgstr "ID und Region"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Kann nicht formatiert werden."
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB Gerät nicht gefunden."
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX ist jetzt geschützt."
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Deinstallieren"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-12-29 11:05+0100\n"
|
||||
"Last-Translator: Springdale\n"
|
||||
"Language-Team: Tusk, Springdale\n"
|
||||
@ -243,6 +243,9 @@ msgstr ""
|
||||
msgid "Both"
|
||||
msgstr "Mindkettõ"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Nem Formázható"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB Meghajtó nem található"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX levédve"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Törlés"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2011-01-22 20:00+0200\n"
|
||||
"Last-Translator: Cambo \n"
|
||||
"Language-Team: Cambo\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Vuoi riavviare?"
|
||||
msgid "Both"
|
||||
msgstr "Entrambi"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Non si può formattare"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "Dispositivo USB non Trovato"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX è Protetto"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Disinstalla"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: ichiroling\n"
|
||||
"Language-Team: hosigumayuugi, papa\n"
|
||||
@ -243,6 +243,9 @@ msgstr "起動しますか?"
|
||||
msgid "Both"
|
||||
msgstr "IDとリージョンを表示"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "初期化できません"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB機器が見つかりません"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "GXは保護されています"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "アンインストール"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: nextos@korea.com\n"
|
||||
"Language-Team: \n"
|
||||
@ -243,6 +243,9 @@ msgstr "부팅?"
|
||||
msgid "Both"
|
||||
msgstr "둘다"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "포맷할 수 없습니다."
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB 장치가 없습니다."
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB 로더 GX 잠김 상태"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "제거"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: raschi\n"
|
||||
"Language-Team: raschi\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Start?"
|
||||
msgid "Both"
|
||||
msgstr "Begge"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Kan ikke formateres"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB enhet ikke funnet"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX er beskyttet"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Avinstallér"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: ziom666 (zadania_prog@vp.pl)\n"
|
||||
"Language-Team: \n"
|
||||
@ -243,6 +243,9 @@ msgstr ""
|
||||
msgid "Both"
|
||||
msgstr "Oba"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Nie mozna sformatowac"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "Nie znaleziono urzadzenia USB"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX zabezpieczony"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Odinstaluj"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-23 18:52+0200\n"
|
||||
"Last-Translator: aniemotion\n"
|
||||
"Language-Team: boto12, aniemotion\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Carregar?"
|
||||
msgid "Both"
|
||||
msgstr "Ambos"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Não pode pode ser formatado"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "Dispositivo USB não encontrado"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "O USB Loader GX está bloqueado"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Desinstalar"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2010-03-22 10:55-0000\n"
|
||||
"Last-Translator: Sky8000\n"
|
||||
"Language-Team: Sky8000 <sky8000@hotmail.com>\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Carregar?"
|
||||
msgid "Both"
|
||||
msgstr "Ambos"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Não pode ser formatado"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "Dispositivo USB não encontrado"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "O USB Loader GX está bloqueado"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Desinstalar"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: nikolai_ca\n"
|
||||
"Language-Team: Kir, alendit, nikolai_ca\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Загрузить?"
|
||||
msgid "Both"
|
||||
msgstr "Оба"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Невозможно отформатировать"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB устройство не найдено"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX заблокирован"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Деинсталлировать"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: knife.hu kavid emul8ion\n"
|
||||
"Language-Team: kavid\n"
|
||||
@ -243,6 +243,9 @@ msgstr "启动?"
|
||||
msgid "Both"
|
||||
msgstr "全部"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "无法格式化"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "找不到 USB 设备"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX 被锁定"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "删除"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: SirPalax\n"
|
||||
"Language-Team: Penn, SirPalax\n"
|
||||
@ -243,6 +243,9 @@ msgstr "¿Ejecutar?"
|
||||
msgid "Both"
|
||||
msgstr "Ambos"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "No se puede formatear"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB no encontrado"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX está protegido"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Desinstalar"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2010-01-19 17:39+0200\n"
|
||||
"Last-Translator: Katsurou\n"
|
||||
"Language-Team: Katsurou, pirateX\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Starta?"
|
||||
msgid "Both"
|
||||
msgstr "Båda"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Kan inte formateras"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB-enhet ej hittad"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX är skyddad"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Avinstallera"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2010-02-15 21:00+0800\n"
|
||||
"Last-Translator: Jane.H\n"
|
||||
"Language-Team: kyogc, Miller, Mika Li, Jane.H\n"
|
||||
@ -243,6 +243,9 @@ msgstr "啟動?"
|
||||
msgid "Both"
|
||||
msgstr "全部"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "無法格式化"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "找不到 USB 設備"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX 被上鎖保護"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "移除"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: Nitro_subzero \n"
|
||||
"Language-Team: Nitro_subzero\n"
|
||||
@ -243,6 +243,9 @@ msgstr "บูต?"
|
||||
msgid "Both"
|
||||
msgstr "ทั้งคู่"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "ไม่สามารถฟอร์แมตได้"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "ไม่พบอุปกรณ์ USB"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX 5 ถูกป้องกัน"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "ถอนการติดตั้ง"
|
||||
|
||||
|
@ -5,7 +5,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: USB Loader GX\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2011-02-05 17:39+0100\n"
|
||||
"POT-Creation-Date: 2011-02-05 22:06+0100\n"
|
||||
"PO-Revision-Date: 2009-10-01 01:00+0200\n"
|
||||
"Last-Translator: omercigingelini\n"
|
||||
"Language-Team: omercigingelini\n"
|
||||
@ -243,6 +243,9 @@ msgstr "Başlat?"
|
||||
msgid "Both"
|
||||
msgstr "İkisi de"
|
||||
|
||||
msgid "Both Ports"
|
||||
msgstr ""
|
||||
|
||||
msgid "Can't be formatted"
|
||||
msgstr "Biçimlendirilemiyor"
|
||||
|
||||
@ -1321,6 +1324,12 @@ msgstr "USB Aygıtı bulunamadı"
|
||||
msgid "USB Loader GX is protected"
|
||||
msgstr "USB Loader GX koruma altında"
|
||||
|
||||
msgid "USB Port"
|
||||
msgstr ""
|
||||
|
||||
msgid "USB Port changing is only supported on Hermes cIOS."
|
||||
msgstr ""
|
||||
|
||||
msgid "Uninstall"
|
||||
msgstr "Kaldır"
|
||||
|
||||
|
File diff suppressed because one or more lines are too long
@ -30,9 +30,11 @@
|
||||
#include <ogc/system.h>
|
||||
#include <sdcard/wiisd_io.h>
|
||||
#include <sdcard/gcsd.h>
|
||||
#include "settings/CSettings.h"
|
||||
#include "usbloader/usbstorage2.h"
|
||||
#include "DeviceHandler.hpp"
|
||||
#include "usbloader/wbfs.h"
|
||||
#include "system/IosLoader.h"
|
||||
|
||||
DeviceHandler * DeviceHandler::instance = NULL;
|
||||
|
||||
@ -159,24 +161,64 @@ static inline bool USBSpinUp()
|
||||
return started;
|
||||
}
|
||||
|
||||
bool DeviceHandler::SetUSBPort(int port)
|
||||
{
|
||||
if(Settings.USBPort != 2)
|
||||
DeviceHandler::Instance()->UnMountAllUSB();
|
||||
|
||||
int ret = USBStorage2_SetPort(port);
|
||||
|
||||
USBSpinUp();
|
||||
|
||||
if(Settings.USBPort != 2)
|
||||
DeviceHandler::Instance()->MountAllUSB();
|
||||
|
||||
return ret >= 0;
|
||||
}
|
||||
|
||||
void DeviceHandler::SetUSBPortFromPartition(int part)
|
||||
{
|
||||
if(Settings.USBPort != 2)
|
||||
return;
|
||||
|
||||
PartitionHandle * usbHandle = DeviceHandler::Instance()->GetUSBHandle();
|
||||
if(!usbHandle)
|
||||
return;
|
||||
|
||||
if(part < usbHandle->GetPartitionCount())
|
||||
SetUSBPort(0);
|
||||
else
|
||||
SetUSBPort(1);
|
||||
}
|
||||
|
||||
bool DeviceHandler::MountUSB(int pos, bool spinup)
|
||||
{
|
||||
if(spinup && !USBSpinUp())
|
||||
return false;
|
||||
|
||||
if(!usb)
|
||||
{
|
||||
if(Settings.USBPort == 2) SetUSBPort(0);
|
||||
usb = new PartitionHandle(GetUSBInterface());
|
||||
if(Settings.USBPort == 2 && IosLoader::IsHermesIOS())
|
||||
{
|
||||
SetUSBPort(1);
|
||||
usb->GetPort1Partitions();
|
||||
}
|
||||
}
|
||||
|
||||
if(usb->GetPartitionCount() < 1)
|
||||
if(usb->GetPartitionTotalCount() < 1)
|
||||
{
|
||||
delete usb;
|
||||
usb = NULL;
|
||||
return false;
|
||||
}
|
||||
|
||||
if(pos >= usb->GetPartitionCount())
|
||||
if(pos >= usb->GetPartitionTotalCount())
|
||||
return false;
|
||||
|
||||
SetUSBPortFromPartition(pos);
|
||||
|
||||
return usb->Mount(pos, DeviceName[USB1+pos]);
|
||||
}
|
||||
|
||||
@ -186,16 +228,27 @@ bool DeviceHandler::MountAllUSB(bool spinup)
|
||||
return false;
|
||||
|
||||
if(!usb)
|
||||
{
|
||||
if(Settings.USBPort == 2) SetUSBPort(0);
|
||||
usb = new PartitionHandle(GetUSBInterface());
|
||||
if(Settings.USBPort == 2 && IosLoader::IsHermesIOS())
|
||||
{
|
||||
SetUSBPort(1);
|
||||
usb->GetPort1Partitions();
|
||||
}
|
||||
}
|
||||
|
||||
bool result = false;
|
||||
|
||||
for(int i = 0; i < usb->GetPartitionCount(); i++)
|
||||
for(int i = 0; i < usb->GetPartitionTotalCount(); i++)
|
||||
{
|
||||
if(MountUSB(i, false))
|
||||
result = true;
|
||||
}
|
||||
|
||||
if(Settings.USBPort == 2)
|
||||
SetUSBPort(0);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
@ -204,9 +257,11 @@ void DeviceHandler::UnMountUSB(int pos)
|
||||
if(!usb)
|
||||
return;
|
||||
|
||||
if(pos >= usb->GetPartitionCount())
|
||||
if(pos >= usb->GetPartitionTotalCount())
|
||||
return;
|
||||
|
||||
SetUSBPortFromPartition(pos);
|
||||
|
||||
usb->UnMount(pos);
|
||||
}
|
||||
|
||||
@ -215,8 +270,8 @@ void DeviceHandler::UnMountAllUSB()
|
||||
if(!usb)
|
||||
return;
|
||||
|
||||
for(int i = 0; i < usb->GetPartitionCount(); i++)
|
||||
usb->UnMount(i);
|
||||
for(int i = 0; i < usb->GetPartitionTotalCount(); i++)
|
||||
UnMountUSB(i);
|
||||
|
||||
delete usb;
|
||||
usb = NULL;
|
||||
|
@ -83,6 +83,8 @@ class DeviceHandler
|
||||
static const char * GetFSName(int dev);
|
||||
static const char * PathToFSName(const char * path) { return GetFSName(PathToDriveType(path)); };
|
||||
static const DISC_INTERFACE * GetUSBInterface();
|
||||
static bool SetUSBPort(int port);
|
||||
static void SetUSBPortFromPartition(int part);
|
||||
private:
|
||||
DeviceHandler() : sd(0), usb(0) { };
|
||||
~DeviceHandler();
|
||||
|
@ -68,6 +68,7 @@ static inline const char * PartFromType(int type)
|
||||
|
||||
PartitionHandle::PartitionHandle(const DISC_INTERFACE *discio)
|
||||
{
|
||||
Port0Size = 0;
|
||||
interface = discio;
|
||||
|
||||
// Sanity check
|
||||
@ -92,6 +93,23 @@ PartitionHandle::~PartitionHandle()
|
||||
interface->shutdown();
|
||||
}
|
||||
|
||||
void PartitionHandle::GetPort1Partitions()
|
||||
{
|
||||
if(Port0Size != 0)
|
||||
return;
|
||||
|
||||
Port0Size = PartitionList.size();
|
||||
|
||||
// Start the device and check that it is inserted
|
||||
if (!interface->startup())
|
||||
return;
|
||||
|
||||
if (!interface->isInserted())
|
||||
return;
|
||||
|
||||
FindPartitions();
|
||||
}
|
||||
|
||||
bool PartitionHandle::IsMounted(int pos)
|
||||
{
|
||||
if(pos < 0 || pos >= (int) MountNameList.size())
|
||||
@ -114,7 +132,7 @@ bool PartitionHandle::Mount(int pos, const char * name, bool forceFAT)
|
||||
UnMount(pos);
|
||||
|
||||
if(pos >= (int) MountNameList.size())
|
||||
MountNameList.resize(GetPartitionCount());
|
||||
MountNameList.resize(pos+1);
|
||||
|
||||
MountNameList[pos] = name;
|
||||
|
||||
@ -236,7 +254,7 @@ int PartitionHandle::FindPartitions()
|
||||
continue;
|
||||
}
|
||||
|
||||
if(le32(partition->block_count) > 0 && !IsExisting(le32(partition->lba_start)))
|
||||
if(le32(partition->block_count) > 0 && (!IsExisting(le32(partition->lba_start)) || Port0Size))
|
||||
{
|
||||
AddPartition(PartFromType(partition->type), le32(partition->lba_start),
|
||||
le32(partition->block_count), (partition->status == PARTITION_BOOTABLE),
|
||||
|
@ -145,24 +145,29 @@ class PartitionHandle
|
||||
//! Get the entrie number in MBR of this partition
|
||||
int GetPartitionNum(int pos) { if(valid(pos)) return PartitionList[pos].PartitionNum; else return -1; };
|
||||
//! Get the count of found partitions
|
||||
int GetPartitionCount() { return PartitionList.size(); };
|
||||
int GetPartitionCount() const { if(Port0Size) return Port0Size; else return PartitionList.size(); };
|
||||
//! Get the partition size in bytes
|
||||
u64 GetSize(int pos) { if(valid(pos)) return (u64) PartitionList[pos].SecCount*BYTES_PER_SECTOR; else return 0; };
|
||||
//! Get the whole partition record struct
|
||||
PartitionFS * GetPartitionRecord(int pos) { if(valid(pos)) return &PartitionList[pos]; else return NULL; };
|
||||
//! Get the disc interface of this handle
|
||||
const DISC_INTERFACE * GetDiscInterface() { return interface; };
|
||||
//! Get the port 1 partitions on usb
|
||||
void GetPort1Partitions();
|
||||
//! Get the count of found partitions including second port partitions on usb
|
||||
int GetPartitionTotalCount() const { return PartitionList.size(); };
|
||||
protected:
|
||||
bool valid(int pos) { return (pos >= 0 && pos < (int) PartitionList.size()); }
|
||||
void AddPartition(const char * name, u64 lba_start, u64 sec_count, bool bootable, u8 part_type, u8 part_num);
|
||||
int FindPartitions();
|
||||
bool IsExisting(u64 lba);
|
||||
int FindPartitions();
|
||||
void CheckEBR(u8 PartNum, sec_t ebr_lba);
|
||||
int CheckGPT(u8 PartNum);
|
||||
|
||||
const DISC_INTERFACE *interface;
|
||||
std::vector<PartitionFS> PartitionList;
|
||||
std::vector<std::string> MountNameList;
|
||||
int Port0Size;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -157,6 +157,14 @@ bool StartUpProcess::Execute()
|
||||
DeviceHandler::Instance()->MountAllUSB(false);
|
||||
}
|
||||
|
||||
if(!IosLoader::IsHermesIOS())
|
||||
Settings.USBPort = 0;
|
||||
else if(Settings.USBPort == 1)
|
||||
{
|
||||
SetTextf("Changing USB Port to %i\n", Settings.USBPort);
|
||||
DeviceHandler::SetUSBPort(Settings.USBPort);
|
||||
}
|
||||
|
||||
gprintf("\tLoading font...%s\n", Theme::LoadFont(Settings.theme_path) ? "done" : "failed (using default)");
|
||||
gprintf("\tLoading theme...%s\n", Theme::Load(Settings.theme) ? "done" : "failed (using default)");
|
||||
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,16 +1,3 @@
|
||||
#ifndef EHC_MODULE5_H_
|
||||
#define EHC_MODULE5_H_
|
||||
#define size_ehcmodule_5 25856
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern unsigned char ehcmodule_5[25883];
|
||||
|
||||
#define ehcmodule_5_size sizeof(ehcmodule_5)
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
extern unsigned char ehcmodule_5[25856];
|
||||
|
@ -114,6 +114,7 @@ void CSettings::SetDefault()
|
||||
widescreen = (CONF_GetAspectRatio() == CONF_ASPECT_16_9);
|
||||
HomeMenu = HOME_MENU_DEFAULT;
|
||||
MultiplePartitions = OFF;
|
||||
USBPort = 0;
|
||||
}
|
||||
|
||||
bool CSettings::Load()
|
||||
@ -255,6 +256,7 @@ bool CSettings::Save()
|
||||
fprintf(file, "returnTo = %s\n ", returnTo);
|
||||
fprintf(file, "HomeMenu = %d\n ", HomeMenu);
|
||||
fprintf(file, "MultiplePartitions = %d\n ", MultiplePartitions);
|
||||
fprintf(file, "USBPort = %d\n ", USBPort);
|
||||
fclose(file);
|
||||
|
||||
return true;
|
||||
@ -462,6 +464,11 @@ bool CSettings::SetSetting(char *name, char *value)
|
||||
if (sscanf(value, "%d", &i) == 1) MultiplePartitions = i;
|
||||
return true;
|
||||
}
|
||||
else if (strcmp(name, "USBPort") == 0)
|
||||
{
|
||||
if (sscanf(value, "%d", &i) == 1) USBPort = i;
|
||||
return true;
|
||||
}
|
||||
else if (strcmp(name, "patchcountrystrings") == 0)
|
||||
{
|
||||
if (sscanf(value, "%d", &i) == 1) patchcountrystrings = i;
|
||||
|
@ -111,6 +111,7 @@ class CSettings
|
||||
short ShowFreeSpace;
|
||||
short HomeMenu;
|
||||
short MultiplePartitions;
|
||||
short USBPort;
|
||||
u32 InstallPartitions;
|
||||
u32 ParentalBlocks;
|
||||
protected:
|
||||
|
@ -25,6 +25,7 @@
|
||||
#include <sys/statvfs.h>
|
||||
#include "LoaderSettings.hpp"
|
||||
#include "Controls/DeviceHandler.hpp"
|
||||
#include "usbloader/usbstorage2.h"
|
||||
#include "settings/CSettings.h"
|
||||
#include "prompts/ProgressWindow.h"
|
||||
#include "prompts/PromptWindows.h"
|
||||
@ -116,6 +117,7 @@ LoaderSettings::LoaderSettings()
|
||||
Options->SetName(Idx++, "%s", tr( "Boot/Standard" ));
|
||||
Options->SetName(Idx++, "%s", tr( "Game/Install Partition" ));
|
||||
Options->SetName(Idx++, "%s", tr( "Multiple Partitions" ));
|
||||
Options->SetName(Idx++, "%s", tr( "USB Port" ));
|
||||
Options->SetName(Idx++, "%s", tr( "Install directories" ));
|
||||
Options->SetName(Idx++, "%s", tr( "Game Split Size" ));
|
||||
Options->SetName(Idx++, "%s", tr( "Quick Boot" ));
|
||||
@ -129,15 +131,24 @@ LoaderSettings::LoaderSettings()
|
||||
|
||||
OldSettingsPartition = Settings.partition;
|
||||
OldSettingsMultiplePartitions = Settings.MultiplePartitions;
|
||||
OldSettingsUSBPort = Settings.USBPort;
|
||||
}
|
||||
|
||||
LoaderSettings::~LoaderSettings()
|
||||
{
|
||||
//! if partition has changed, Reinitialize it
|
||||
if (Settings.partition != OldSettingsPartition ||
|
||||
Settings.MultiplePartitions != OldSettingsMultiplePartitions)
|
||||
Settings.MultiplePartitions != OldSettingsMultiplePartitions ||
|
||||
Settings.USBPort != OldSettingsUSBPort)
|
||||
{
|
||||
int tempPort = Settings.USBPort;
|
||||
Settings.USBPort = OldSettingsUSBPort;
|
||||
WBFS_CloseAll();
|
||||
DeviceHandler::Instance()->UnMountAllUSB();
|
||||
Settings.USBPort = tempPort;
|
||||
DeviceHandler::SetUSBPort(Settings.USBPort);
|
||||
if(Settings.USBPort == 2) DeviceHandler::Instance()->MountAllUSB();
|
||||
|
||||
if(Settings.MultiplePartitions)
|
||||
WBFS_OpenAll();
|
||||
else
|
||||
@ -182,6 +193,12 @@ void LoaderSettings::SetOptionValues()
|
||||
//! Settings: Multiple Partitions
|
||||
Options->SetValue(Idx++, "%s", tr( OnOffText[Settings.MultiplePartitions] ));
|
||||
|
||||
//! Settings: USB Port
|
||||
if(Settings.USBPort == 2)
|
||||
Options->SetValue(Idx++, tr("Both Ports"));
|
||||
else
|
||||
Options->SetValue(Idx++, "%i", Settings.USBPort);
|
||||
|
||||
//! Settings: Install directories
|
||||
Options->SetValue(Idx++, "%s", tr( InstallToText[Settings.InstallToDir] ));
|
||||
|
||||
@ -290,7 +307,7 @@ int LoaderSettings::GetMenuInternal()
|
||||
int retries = 20;
|
||||
do
|
||||
{
|
||||
Settings.partition = (Settings.partition + 1) % DeviceHandler::Instance()->GetUSBHandle()->GetPartitionCount();
|
||||
Settings.partition = (Settings.partition + 1) % DeviceHandler::Instance()->GetUSBHandle()->GetPartitionTotalCount();
|
||||
fs_type = DeviceHandler::GetUSBFilesystemType(Settings.partition);
|
||||
}
|
||||
while (!IsValidPartition(fs_type, ios) && --retries > 0);
|
||||
@ -305,6 +322,19 @@ int LoaderSettings::GetMenuInternal()
|
||||
if (++Settings.MultiplePartitions >= MAX_ON_OFF) Settings.MultiplePartitions = 0;
|
||||
}
|
||||
|
||||
//! Settings: USB Port
|
||||
else if (ret == ++Idx)
|
||||
{
|
||||
if(!IosLoader::IsHermesIOS())
|
||||
{
|
||||
WindowPrompt(tr("ERROR:"), tr("USB Port changing is only supported on Hermes cIOS."), tr("OK"));
|
||||
Settings.USBPort = 0;
|
||||
}
|
||||
|
||||
else if (++Settings.USBPort >= 3) // 2 = both ports
|
||||
Settings.USBPort = 0;
|
||||
}
|
||||
|
||||
//! Settings: Install directories
|
||||
else if (ret == ++Idx)
|
||||
{
|
||||
|
@ -38,6 +38,7 @@ class LoaderSettings : public SettingsMenu
|
||||
|
||||
int OldSettingsPartition;
|
||||
int OldSettingsMultiplePartitions;
|
||||
int OldSettingsUSBPort;
|
||||
|
||||
OptionList GuiOptions;
|
||||
};
|
||||
|
@ -147,19 +147,18 @@ void IosLoader::LoadIOSModules(s32 ios, s32 ios_rev)
|
||||
int dip_plugin_size = 0;
|
||||
|
||||
ech_module = ehcmodule_5;
|
||||
ehc_module_size = ehcmodule_5_size;
|
||||
ehc_module_size = size_ehcmodule_5;
|
||||
dip_plugin = odip_frag;
|
||||
dip_plugin_size = odip_frag_size;
|
||||
gprintf("Loading ehc v5 and opendip module\n");
|
||||
|
||||
u8 *ehc_cfg = search_for_ehcmodule_cfg((u8 *) ech_module, ehc_module_size);
|
||||
if (ehc_cfg)
|
||||
{
|
||||
ehc_cfg += 12;
|
||||
ehc_cfg[0] = 0; // USB Port 0
|
||||
gprintf("Patched ehc module to use usb port 0.\n");
|
||||
}
|
||||
|
||||
// u8 *ehc_cfg = search_for_ehcmodule_cfg((u8 *) ech_module, ehc_module_size);
|
||||
// if (ehc_cfg)
|
||||
// {
|
||||
// ehc_cfg += 12;
|
||||
// ehc_cfg[0] = 0; // USB Port 0
|
||||
// gprintf("Patched ehc module to use usb port 0.\n");
|
||||
// }
|
||||
load_modules(ech_module, ehc_module_size, dip_plugin, dip_plugin_size);
|
||||
}
|
||||
//! Waninkoko IOS
|
||||
|
@ -6,6 +6,7 @@
|
||||
#include "Controls/DeviceHandler.hpp"
|
||||
#include "usbloader/disc.h"
|
||||
#include "usbloader/apploader.h"
|
||||
#include "usbloader/usbstorage2.h"
|
||||
#include "usbloader/wdvd.h"
|
||||
#include "usbloader/GameList.h"
|
||||
#include "settings/Settings.h"
|
||||
@ -243,7 +244,7 @@ int GameBooter::BootGame(const char * gameID)
|
||||
if (gameList.GetGameFS(gameHeader.id) == PART_FS_WBFS)
|
||||
mload_close();
|
||||
}
|
||||
|
||||
|
||||
//! Now we can free up the memory used by the game list
|
||||
gameList.clear();
|
||||
|
||||
@ -267,11 +268,22 @@ int GameBooter::BootGame(const char * gameID)
|
||||
//! Shadow mload - Only needed on some games with Hermes v5.1 (Check is inside the function)
|
||||
shadow_mload();
|
||||
|
||||
//! Remember game's USB port
|
||||
int usbport = USBStorage2_GetPort();
|
||||
|
||||
//! Flush all caches and close up all devices
|
||||
WBFS_CloseAll();
|
||||
DeviceHandler::DestroyInstance();
|
||||
USB_Deinitialize();
|
||||
|
||||
if(Settings.USBPort == 2)
|
||||
{
|
||||
//! Reset USB port because device handler changes it for cache flushing
|
||||
USBStorage2_Init();
|
||||
USBStorage2_SetPort(usbport);
|
||||
USBStorage2_Deinit();
|
||||
}
|
||||
|
||||
//! Modify Wii Message Board to display the game starting here
|
||||
if(Settings.PlaylogUpdate)
|
||||
Playlog_Update((char *) gameHeader.id, BNRInstance::Instance()->GetIMETTitle(CONF_GetLanguage()));
|
||||
|
@ -169,7 +169,7 @@ int GameList::ReadGameList()
|
||||
PartitionHandle * usbHandle = DeviceHandler::Instance()->GetUSBHandle();
|
||||
int cnt = 0;
|
||||
|
||||
for(int part = 0; part < usbHandle->GetPartitionCount(); ++part)
|
||||
for(int part = 0; part < usbHandle->GetPartitionTotalCount(); ++part)
|
||||
{
|
||||
int ret = InternalReadList(part);
|
||||
if(ret > 0) cnt += ret;
|
||||
|
@ -1,6 +1,8 @@
|
||||
/*-------------------------------------------------------------
|
||||
|
||||
usbstorage_starlet.c -- USB mass storage support, inside starlet
|
||||
Copyright (C) 2011 Dimok
|
||||
Copyright (C) 2011 Rodries
|
||||
Copyright (C) 2009 Kwiirk
|
||||
|
||||
If this driver is linked before libogc, this will replace the original
|
||||
@ -32,6 +34,7 @@
|
||||
#include <string.h>
|
||||
#include "usbstorage2.h"
|
||||
#include "memory/mem2.h"
|
||||
#include "gecko.h"
|
||||
|
||||
|
||||
/* IOCTL commands */
|
||||
@ -46,6 +49,7 @@
|
||||
#define USB_IOCTL_UMS_WATCHDOG (UMS_BASE+0x80)
|
||||
|
||||
#define USB_IOCTL_UMS_TESTMODE (UMS_BASE+0x81)
|
||||
#define USB_IOCTL_SET_PORT (UMS_BASE+0x83)
|
||||
|
||||
#define WBFS_BASE (('W'<<24)|('F'<<16)|('S'<<8))
|
||||
#define USB_IOCTL_WBFS_OPEN_DISC (WBFS_BASE+0x1)
|
||||
@ -65,6 +69,7 @@ static char fs3[] ATTRIBUTE_ALIGN(32) = "/dev/usb/ehc";
|
||||
|
||||
static u8 * mem2_ptr = NULL;
|
||||
static s32 hid = -1, fd = -1;
|
||||
static u32 usb2_port = 0; //autodetect mode (works only with hermes ios & rodries ehcmodule)
|
||||
u32 hdd_sector_size = 512;
|
||||
|
||||
s32 USBStorage2_Init(void)
|
||||
@ -85,9 +90,10 @@ s32 USBStorage2_Init(void)
|
||||
fd = IOS_Open(fs, 0);
|
||||
if (fd < 0) fd = IOS_Open(fs2, 0);
|
||||
if (fd < 0) fd = IOS_Open(fs3, 0);
|
||||
|
||||
if (fd < 0) return fd;
|
||||
|
||||
IOS_IoctlvFormat(hid, fd, USB_IOCTL_SET_PORT, "i:", usb2_port);
|
||||
|
||||
/* Initialize USB storage */
|
||||
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_UMS_INIT, ":");
|
||||
if (ret < 0) goto err;
|
||||
@ -124,6 +130,29 @@ void USBStorage2_Deinit(void)
|
||||
hdd_sector_size = 512;
|
||||
}
|
||||
|
||||
s32 USBStorage2_SetPort(u32 port)
|
||||
{
|
||||
if(port < 0 || port > 1)
|
||||
return -1;
|
||||
|
||||
if(port == usb2_port)
|
||||
return 0;
|
||||
|
||||
s32 ret = -1;
|
||||
usb2_port = port;
|
||||
|
||||
gprintf("Changing USB port to port %i....\n", port);
|
||||
//must be called before USBStorage2_Init (default port 0)
|
||||
if (fd >= 0)
|
||||
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_SET_PORT, "i:", usb2_port);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
s32 USBStorage2_GetPort()
|
||||
{
|
||||
return usb2_port;
|
||||
}
|
||||
|
||||
s32 USBStorage2_Watchdog(u32 on_off)
|
||||
{
|
||||
@ -245,7 +274,7 @@ s32 USBStorage2_WriteSectors(u32 sector, u32 numSectors, const void *buffer)
|
||||
|
||||
static bool __usbstorage_Startup(void)
|
||||
{
|
||||
return USBStorage2_Init() == 0;
|
||||
return USBStorage2_Init() >= 0;
|
||||
}
|
||||
|
||||
static bool __usbstorage_IsInserted(void)
|
||||
@ -283,64 +312,3 @@ const DISC_INTERFACE __io_usbstorage2 = {
|
||||
(FN_MEDIUM_CLEARSTATUS) &__usbstorage_ClearStatus,
|
||||
(FN_MEDIUM_SHUTDOWN) &__usbstorage_Shutdown
|
||||
};
|
||||
|
||||
// woffset is in 32bit words, len is in bytes
|
||||
s32 USBStorage_WBFS_Read(u32 woffset, u32 len, void *buffer)
|
||||
{
|
||||
s32 ret;
|
||||
|
||||
USBStorage2_Init();
|
||||
/* Device not opened */
|
||||
if (fd < 0) return fd;
|
||||
|
||||
/* Read data */
|
||||
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_WBFS_READ_DISC, "ii:d", woffset, len, buffer, len);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
s32 USBStorage_WBFS_SetFragList(void *p, int size)
|
||||
{
|
||||
s32 ret;
|
||||
USBStorage2_Init();
|
||||
// Device not opened
|
||||
if (fd < 0) return fd;
|
||||
// ioctl
|
||||
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_WBFS_SET_FRAGLIST, "d:", p, size);
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Not used currently
|
||||
#if 0
|
||||
|
||||
s32 USBStorage_WBFS_Open(char *buffer)
|
||||
{
|
||||
u32 len = 8;
|
||||
|
||||
s32 ret;
|
||||
|
||||
/* Device not opened */
|
||||
if (fd < 0) return fd;
|
||||
|
||||
extern u32 wbfs_part_lba;
|
||||
u32 part = wbfs_part_lba;
|
||||
|
||||
/* Read data */
|
||||
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_WBFS_OPEN_DISC, "dd:", buffer, len, &part, 4);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
s32 USBStorage_WBFS_SetDevice(int dev)
|
||||
{
|
||||
s32 ret, retval = 0;
|
||||
USBStorage2_Init();
|
||||
// Device not opened
|
||||
if (fd < 0) return fd;
|
||||
// ioctl
|
||||
ret = IOS_IoctlvFormat(hid, fd, USB_IOCTL_WBFS_SET_DEVICE, "i:i", dev, &retval);
|
||||
if (retval) return retval;
|
||||
return ret;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -19,9 +19,8 @@ extern "C"
|
||||
|
||||
s32 USBStorage2_Watchdog(u32 on_off);
|
||||
|
||||
s32 USBStorage_WBFS_Read(u32 woffset, u32 len, void *buffer);
|
||||
s32 USBStorage_WBFS_SetDevice(int dev);
|
||||
s32 USBStorage_WBFS_SetFragList(void *p, int size);
|
||||
s32 USBStorage2_SetPort(u32 port);
|
||||
s32 USBStorage2_GetPort();
|
||||
|
||||
#define DEVICE_TYPE_WII_UMS (('W'<<24)|('U'<<16)|('M'<<8)|'S')
|
||||
|
||||
|
@ -25,10 +25,12 @@ wbfs_disc_t* WBFS_OpenDisc(u8 *discid)
|
||||
if(!discid) return NULL;
|
||||
|
||||
int part = gameList.GetPartitionNumber(discid);
|
||||
if(VALID(part))
|
||||
return WbfsList[part]->OpenDisc(discid);
|
||||
if(!VALID(part))
|
||||
return NULL;
|
||||
|
||||
return NULL;
|
||||
DeviceHandler::SetUSBPortFromPartition(part);
|
||||
|
||||
return WbfsList[part]->OpenDisc(discid);
|
||||
}
|
||||
|
||||
void WBFS_CloseDisc(wbfs_disc_t *disc)
|
||||
@ -40,6 +42,8 @@ void WBFS_CloseDisc(wbfs_disc_t *disc)
|
||||
if(!VALID(part_num))
|
||||
return;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
WbfsList[part_num]->CloseDisc(disc);
|
||||
}
|
||||
|
||||
@ -54,7 +58,7 @@ s32 WBFS_OpenAll()
|
||||
|
||||
PartitionHandle * usbHandle = DeviceHandler::Instance()->GetUSBHandle();
|
||||
|
||||
for(int i = 0; i < usbHandle->GetPartitionCount(); ++i)
|
||||
for(int i = 0; i < usbHandle->GetPartitionTotalCount(); ++i)
|
||||
{
|
||||
if(WBFS_OpenPart(i) == 0)
|
||||
ret = 0;
|
||||
@ -66,9 +70,11 @@ s32 WBFS_OpenAll()
|
||||
s32 WBFS_OpenPart(int part_num)
|
||||
{
|
||||
PartitionHandle * usbHandle = DeviceHandler::Instance()->GetUSBHandle();
|
||||
if(part_num < 0 || part_num >= usbHandle->GetPartitionCount())
|
||||
if(part_num < 0 || part_num >= usbHandle->GetPartitionTotalCount())
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
// close
|
||||
WBFS_Close(part_num);
|
||||
|
||||
@ -79,19 +85,19 @@ s32 WBFS_OpenPart(int part_num)
|
||||
|
||||
if (strncmp(usbHandle->GetFSName(part_num), "FAT", 3) == 0)
|
||||
{
|
||||
WbfsList[part_num] = new Wbfs_Fat(WBFS_MIN_DEVICE, usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num));
|
||||
WbfsList[part_num] = new Wbfs_Fat(usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num), part_num);
|
||||
}
|
||||
else if (strncmp(usbHandle->GetFSName(part_num), "NTFS", 4) == 0)
|
||||
{
|
||||
WbfsList[part_num] = new Wbfs_Ntfs(WBFS_MIN_DEVICE, usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num));
|
||||
WbfsList[part_num] = new Wbfs_Ntfs(usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num), part_num);
|
||||
}
|
||||
else if (strncmp(usbHandle->GetFSName(part_num), "LINUX", 5) == 0)
|
||||
{
|
||||
WbfsList[part_num] = new Wbfs_Ext(WBFS_MIN_DEVICE, usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num));
|
||||
WbfsList[part_num] = new Wbfs_Ext(usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num), part_num);
|
||||
}
|
||||
else if (strncmp(usbHandle->GetFSName(part_num), "WBFS", 4) == 0)
|
||||
{
|
||||
WbfsList[part_num] = new Wbfs_Wbfs(WBFS_MIN_DEVICE, usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num));
|
||||
WbfsList[part_num] = new Wbfs_Wbfs(usbHandle->GetLBAStart(part_num), usbHandle->GetSecCount(part_num), part_num);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -113,6 +119,8 @@ bool WBFS_Close(int part_num)
|
||||
if(!VALID(part_num))
|
||||
return false;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
delete WbfsList[part_num];
|
||||
WbfsList[part_num] = NULL;
|
||||
|
||||
@ -141,7 +149,10 @@ s32 WBFS_GetCount(int part_num, u32 *count)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
return WbfsList[part_num]->GetCount(count);
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
int ret = WbfsList[part_num]->GetCount(count);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
s32 WBFS_GetHeaders(int part_num, struct discHdr *outbuf, u32 cnt, u32 len)
|
||||
@ -149,6 +160,8 @@ s32 WBFS_GetHeaders(int part_num, struct discHdr *outbuf, u32 cnt, u32 len)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->GetHeaders(outbuf, cnt, len);
|
||||
}
|
||||
|
||||
@ -158,6 +171,8 @@ s32 WBFS_CheckGame(u8 *discid)
|
||||
if(!VALID(part_num))
|
||||
return 0;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->CheckGame(discid);
|
||||
}
|
||||
|
||||
@ -166,6 +181,8 @@ s32 WBFS_AddGame(void)
|
||||
if(!VALID(Settings.partition))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(Settings.partition);
|
||||
|
||||
return WbfsList[Settings.partition]->AddGame();
|
||||
}
|
||||
|
||||
@ -175,6 +192,8 @@ s32 WBFS_RemoveGame(u8 *discid)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->RemoveGame(discid);
|
||||
}
|
||||
|
||||
@ -184,6 +203,8 @@ s32 WBFS_GameSize(u8 *discid, f32 *size)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->GameSize(discid, size);
|
||||
}
|
||||
|
||||
@ -192,6 +213,8 @@ s32 WBFS_DiskSpace(f32 *used, f32 *free)
|
||||
if(!VALID(Settings.partition))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(Settings.partition);
|
||||
|
||||
return WbfsList[Settings.partition]->DiskSpace(used, free);
|
||||
}
|
||||
|
||||
@ -201,6 +224,8 @@ s32 WBFS_RenameGame(u8 *discid, const void *newname)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->RenameGame(discid, newname);
|
||||
}
|
||||
|
||||
@ -210,6 +235,8 @@ s32 WBFS_ReIDGame(u8 *discid, const void *newID)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->ReIDGame(discid, newID);
|
||||
}
|
||||
|
||||
@ -218,6 +245,8 @@ u64 WBFS_EstimeGameSize(void)
|
||||
if(!VALID(Settings.partition))
|
||||
return 0;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(Settings.partition);
|
||||
|
||||
return WbfsList[Settings.partition]->EstimateGameSize();
|
||||
}
|
||||
|
||||
@ -227,6 +256,8 @@ int WBFS_GetFragList(u8 *id)
|
||||
if(!VALID(part_num))
|
||||
return -1;
|
||||
|
||||
DeviceHandler::SetUSBPortFromPartition(part_num);
|
||||
|
||||
return WbfsList[part_num]->GetFragList(id);
|
||||
}
|
||||
|
||||
|
@ -12,8 +12,8 @@
|
||||
|
||||
#include "wbfs_base.h"
|
||||
|
||||
Wbfs::Wbfs(u32 dev, u32 l, u32 s)
|
||||
: hdd(NULL), device(dev), lba(l), size(s)
|
||||
Wbfs::Wbfs(u32 l, u32 s, u32 part)
|
||||
: hdd(NULL), lba(l), size(s), partition(part)
|
||||
{
|
||||
}
|
||||
|
||||
@ -22,7 +22,7 @@ s32 Wbfs::Init(u32 device)
|
||||
s32 ret;
|
||||
const DISC_INTERFACE * handle = DeviceHandler::GetUSBInterface();
|
||||
|
||||
switch (device)
|
||||
switch (WBFS_DEVICE_USB)
|
||||
{
|
||||
case WBFS_DEVICE_USB:
|
||||
/* Initialize USB storage */
|
||||
|
@ -11,7 +11,7 @@
|
||||
class Wbfs
|
||||
{
|
||||
public:
|
||||
Wbfs(u32 dev, u32 lba, u32 size);
|
||||
Wbfs(u32 lba, u32 size, u32 part);
|
||||
~Wbfs() { Close(); };
|
||||
static s32 Init(u32);
|
||||
s32 CheckGame(u8 *);
|
||||
@ -37,9 +37,9 @@ class Wbfs
|
||||
const wbfs_t *GetHDDHandle(void) const { return hdd; }
|
||||
protected:
|
||||
wbfs_t *hdd;
|
||||
const u32 device;
|
||||
const u32 lba;
|
||||
const u32 size;
|
||||
const u32 partition;
|
||||
};
|
||||
|
||||
#endif //_H
|
||||
|
@ -6,8 +6,8 @@
|
||||
class Wbfs_Ext: public Wbfs_Fat
|
||||
{
|
||||
public:
|
||||
Wbfs_Ext(u32 device, u32 lba, u32 size) :
|
||||
Wbfs_Fat(device, lba, size)
|
||||
Wbfs_Ext(u32 lba, u32 size, u32 part) :
|
||||
Wbfs_Fat(lba, size, part)
|
||||
{
|
||||
}
|
||||
virtual const u8 GetFSType(void) const { return PART_FS_EXT; }
|
||||
|
@ -38,8 +38,8 @@ static const char wbfs_fat_dir[] = "/wbfs";
|
||||
static const char invalid_path[] = "/\\:|<>?*\"'";
|
||||
extern u32 hdd_sector_size;
|
||||
|
||||
Wbfs_Fat::Wbfs_Fat(u32 device, u32 lba, u32 size) :
|
||||
Wbfs(device, lba, size), fat_hdr_list(NULL), fat_hdr_count(0)
|
||||
Wbfs_Fat::Wbfs_Fat(u32 lba, u32 size, u32 part) :
|
||||
Wbfs(lba, size, part), fat_hdr_list(NULL), fat_hdr_count(0)
|
||||
{
|
||||
memset(wbfs_fs_drive, 0, sizeof(wbfs_fs_drive));
|
||||
}
|
||||
@ -50,11 +50,11 @@ s32 Wbfs_Fat::Open()
|
||||
|
||||
PartitionHandle * usbHandle = DeviceHandler::Instance()->GetUSBHandle();
|
||||
|
||||
for(int i = 0; i < usbHandle->GetPartitionCount(); ++i)
|
||||
if(partition >= 0 && partition < usbHandle->GetPartitionTotalCount())
|
||||
{
|
||||
if (device == WBFS_DEVICE_USB && lba == usbHandle->GetLBAStart(i))
|
||||
if (lba == usbHandle->GetLBAStart(partition))
|
||||
{
|
||||
sprintf(wbfs_fs_drive, "%s:", usbHandle->MountName(i));
|
||||
sprintf(wbfs_fs_drive, "%s:", usbHandle->MountName(partition));
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
@ -10,7 +10,7 @@
|
||||
class Wbfs_Fat: public Wbfs
|
||||
{
|
||||
public:
|
||||
Wbfs_Fat(u32 device, u32 lba, u32 size);
|
||||
Wbfs_Fat(u32 lba, u32 size, u32 part);
|
||||
|
||||
virtual s32 Open();
|
||||
virtual void Close();
|
||||
|
@ -6,8 +6,8 @@
|
||||
class Wbfs_Ntfs: public Wbfs_Fat
|
||||
{
|
||||
public:
|
||||
Wbfs_Ntfs(u32 device, u32 lba, u32 size) :
|
||||
Wbfs_Fat(device, lba, size)
|
||||
Wbfs_Ntfs(u32 lba, u32 size, u32 part) :
|
||||
Wbfs_Fat(lba, size, part)
|
||||
{
|
||||
}
|
||||
virtual const u8 GetFSType(void) const { return PART_FS_NTFS; }
|
||||
|
Loading…
Reference in New Issue
Block a user