diff --git a/app/src/main/java/org/andbootmgr/app/CreatePartFlow.kt b/app/src/main/java/org/andbootmgr/app/CreatePartFlow.kt
index 2083d035..42f6c35a 100644
--- a/app/src/main/java/org/andbootmgr/app/CreatePartFlow.kt
+++ b/app/src/main/java/org/andbootmgr/app/CreatePartFlow.kt
@@ -1037,6 +1037,7 @@ private fun Flash(c: CreatePartDataHolder) {
 			makeOne(0)
 		} else { // Portable partition
 			terminal.add(vm.activity.getString(R.string.term_create_part))
+			vm.logic.unmountBootset()
 			val r = vm.logic.create(c.p,
 					c.l.toLong(),
 					c.u.toLong(),
diff --git a/app/src/main/java/org/andbootmgr/app/MainActivity.kt b/app/src/main/java/org/andbootmgr/app/MainActivity.kt
index 77643cfa..f2a376a7 100644
--- a/app/src/main/java/org/andbootmgr/app/MainActivity.kt
+++ b/app/src/main/java/org/andbootmgr/app/MainActivity.kt
@@ -7,6 +7,7 @@ import android.util.Log
 import android.view.WindowManager
 import android.widget.Toast
 import androidx.activity.ComponentActivity
+import androidx.activity.compose.BackHandler
 import androidx.activity.compose.setContent
 import androidx.activity.result.ActivityResultLauncher
 import androidx.activity.result.contract.ActivityResultContracts
@@ -76,7 +77,6 @@ class MainActivityState(val activity: MainActivity?) {
 	var wizardCompat by mutableStateOf<String?>(null)
 
 	fun startFlow(flow: String) {
-		unmountBootset()
 		wizardCompat = flow
 	}
 
@@ -268,20 +268,22 @@ class MainActivity : ComponentActivity() {
 								window.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON)
 								onDispose { window.clearFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON) }
 							}
+							BackHandler {}
 							Column(modifier = Modifier.fillMaxSize()) {
-								Terminal(null, { canFinish = true }, null)
+								Row(modifier = Modifier.fillMaxWidth().weight(1.0f)) {
+									Terminal(null, { canFinish = true }, null)
+								}
 								Row(modifier = Modifier.fillMaxWidth()) {
 									TextButton(onClick = {
 									}, modifier = Modifier.weight(1f, true)) {
 										Text("") // This button is useless.
 									}
 									TextButton(onClick = {
-										if (canFinish) {
+										if (canFinish)
 											CoroutineScope(Dispatchers.IO).launch {
 												vm.init()
 												showTerminal = false
 											}
-										}
 									}, modifier = Modifier.weight(1f, true)) {
 										Text(if (canFinish) stringResource(R.string.finish) else "")
 									}
diff --git a/app/src/main/java/org/andbootmgr/app/WizardActivity.kt b/app/src/main/java/org/andbootmgr/app/WizardActivity.kt
index 71774ff8..670924b6 100644
--- a/app/src/main/java/org/andbootmgr/app/WizardActivity.kt
+++ b/app/src/main/java/org/andbootmgr/app/WizardActivity.kt
@@ -124,7 +124,6 @@ class WizardActivityState(val mvm: MainActivityState) {
 		mvm.wizardCompatE = null
 		mvm.wizardCompatPid = null
 		mvm.wizardCompatSid = null
-		mvm.mountBootset()
 	}
 
 	fun copy(inputStream: InputStream, outputStream: OutputStream): Long {
diff --git a/app/src/main/java/org/andbootmgr/app/util/Terminal.kt b/app/src/main/java/org/andbootmgr/app/util/Terminal.kt
index 2866b118..b6636647 100644
--- a/app/src/main/java/org/andbootmgr/app/util/Terminal.kt
+++ b/app/src/main/java/org/andbootmgr/app/util/Terminal.kt
@@ -177,7 +177,7 @@ fun Terminal(logFile: String? = null, doWhenDone: (() -> Unit)? = null,
 				}, s)
 			} else {
 				val s = service.workExtra as BudgetCallbackList
-				text.value = s.joinToString("\n")
+				text.value = s.joinToString("\n").let { if (s.isNotEmpty()) it + "\n" else it }
 				s.cb = { element ->
 					scope.launch {
 						text.value += element + "\n"