|  |  | @ -11,14 +11,11 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  | #define NVME "/dev/nvme0n1" |  |  |  | #define NVME "/dev/nvme0n1" | 
			
		
	
		
		
			
				
					
					|  |  |  | #define USERDATA "/dev/disk/by-partlabel/userdata" |  |  |  | #define USERDATA "/dev/disk/by-partlabel/userdata" | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | void Reset::doReset() { |  |  |  | void Reset::doErase() { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   // best effort to wipe nvme and sd card
 |  |  |  |   // best effort to wipe nvme
 | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   std::system("sudo umount " NVME); |  |  |  |   std::system("sudo umount " NVME); | 
			
		
	
		
		
			
				
					
					|  |  |  |   std::system("yes | sudo mkfs.ext4 " NVME); |  |  |  |   std::system("yes | sudo mkfs.ext4 " NVME); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   // we handle two cases here
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   //  * user-prompted factory reset
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   //  * recovering from a corrupt userdata by formatting
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   int rm = std::system("sudo rm -rf /data/*"); |  |  |  |   int rm = std::system("sudo rm -rf /data/*"); | 
			
		
	
		
		
			
				
					
					|  |  |  |   std::system("sudo umount " USERDATA); |  |  |  |   std::system("sudo umount " USERDATA); | 
			
		
	
		
		
			
				
					
					|  |  |  |   int fmt = std::system("yes | sudo mkfs.ext4 " USERDATA); |  |  |  |   int fmt = std::system("yes | sudo mkfs.ext4 " USERDATA); | 
			
		
	
	
		
		
			
				
					|  |  | @ -30,22 +27,26 @@ void Reset::doReset() { | 
			
		
	
		
		
			
				
					
					|  |  |  |   rebootBtn->show(); |  |  |  |   rebootBtn->show(); | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | void Reset::confirm() { |  |  |  | void Reset::startReset() { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   const QString confirm_txt = tr("Are you sure you want to reset your device?"); |  |  |  |   body->setText(tr("Resetting device...\nThis may take up to a minute.")); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   if (body->text() != confirm_txt) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     body->setText(confirm_txt); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   } else { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     body->setText(tr("Resetting device...")); |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   rejectBtn->hide(); |  |  |  |   rejectBtn->hide(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   rebootBtn->hide(); |  |  |  |   rebootBtn->hide(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   confirmBtn->hide(); |  |  |  |   confirmBtn->hide(); | 
			
		
	
		
		
			
				
					
					|  |  |  | #ifdef __aarch64__ |  |  |  | #ifdef __aarch64__ | 
			
		
	
		
		
			
				
					
					|  |  |  |     QTimer::singleShot(100, this, &Reset::doReset); |  |  |  |   QTimer::singleShot(100, this, &Reset::doErase); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | #endif |  |  |  | #endif | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | void Reset::confirm() { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   const QString confirm_txt = tr("Are you sure you want to reset your device?"); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   if (body->text() != confirm_txt) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     body->setText(confirm_txt); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     startReset(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | Reset::Reset(bool recover, QWidget *parent) : QWidget(parent) { |  |  |  | Reset::Reset(ResetMode mode, QWidget *parent) : QWidget(parent) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   QVBoxLayout *main_layout = new QVBoxLayout(this); |  |  |  |   QVBoxLayout *main_layout = new QVBoxLayout(this); | 
			
		
	
		
		
			
				
					
					|  |  |  |   main_layout->setContentsMargins(45, 220, 45, 45); |  |  |  |   main_layout->setContentsMargins(45, 220, 45, 45); | 
			
		
	
		
		
			
				
					
					|  |  |  |   main_layout->setSpacing(0); |  |  |  |   main_layout->setSpacing(0); | 
			
		
	
	
		
		
			
				
					|  |  | @ -56,7 +57,7 @@ Reset::Reset(bool recover, QWidget *parent) : QWidget(parent) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   main_layout->addSpacing(60); |  |  |  |   main_layout->addSpacing(60); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   body = new QLabel(tr("System reset triggered. Press confirm to erase all content and settings. Press cancel to resume boot.")); |  |  |  |   body = new QLabel(tr("Press confirm to erase all content and settings. Press cancel to resume boot.")); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   body->setWordWrap(true); |  |  |  |   body->setWordWrap(true); | 
			
		
	
		
		
			
				
					
					|  |  |  |   body->setStyleSheet("font-size: 80px; font-weight: light;"); |  |  |  |   body->setStyleSheet("font-size: 80px; font-weight: light;"); | 
			
		
	
		
		
			
				
					
					|  |  |  |   main_layout->addWidget(body, 1, Qt::AlignTop | Qt::AlignLeft); |  |  |  |   main_layout->addWidget(body, 1, Qt::AlignTop | Qt::AlignLeft); | 
			
		
	
	
		
		
			
				
					|  |  | @ -82,10 +83,16 @@ Reset::Reset(bool recover, QWidget *parent) : QWidget(parent) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   blayout->addWidget(confirmBtn); |  |  |  |   blayout->addWidget(confirmBtn); | 
			
		
	
		
		
			
				
					
					|  |  |  |   QObject::connect(confirmBtn, &QPushButton::clicked, this, &Reset::confirm); |  |  |  |   QObject::connect(confirmBtn, &QPushButton::clicked, this, &Reset::confirm); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   bool recover = mode == ResetMode::RECOVER; | 
			
		
	
		
		
			
				
					
					|  |  |  |   rejectBtn->setVisible(!recover); |  |  |  |   rejectBtn->setVisible(!recover); | 
			
		
	
		
		
			
				
					
					|  |  |  |   rebootBtn->setVisible(recover); |  |  |  |   rebootBtn->setVisible(recover); | 
			
		
	
		
		
			
				
					
					|  |  |  |   if (recover) { |  |  |  |   if (recover) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     body->setText(tr("Unable to mount data partition. Press confirm to reset your device.")); |  |  |  |     body->setText(tr("Unable to mount data partition. Partition may be corrupted. Press confirm to erase and reset your device.")); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   // automatically start if we're just finishing up an ABL reset
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   if (mode == ResetMode::FORMAT) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     startReset(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   setStyleSheet(R"( |  |  |  |   setStyleSheet(R"( | 
			
		
	
	
		
		
			
				
					|  |  | @ -108,9 +115,17 @@ Reset::Reset(bool recover, QWidget *parent) : QWidget(parent) { | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | int main(int argc, char *argv[]) { |  |  |  | int main(int argc, char *argv[]) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   bool recover = argc > 1 && strcmp(argv[1], "--recover") == 0; |  |  |  |   ResetMode mode = ResetMode::USER_RESET; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   if (argc > 1) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (strcmp(argv[1], "--recover") == 0) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       mode = ResetMode::RECOVER; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } else if (strcmp(argv[1], "--format") == 0) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       mode = ResetMode::FORMAT; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   QApplication a(argc, argv); |  |  |  |   QApplication a(argc, argv); | 
			
		
	
		
		
			
				
					
					|  |  |  |   Reset reset(recover); |  |  |  |   Reset reset(mode); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   setMainWindow(&reset); |  |  |  |   setMainWindow(&reset); | 
			
		
	
		
		
			
				
					
					|  |  |  |   return a.exec(); |  |  |  |   return a.exec(); | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					|  |  | 
 |