5 Commits

Author SHA1 Message Date
Self Not Found b74ad1b0de Merge pull request #70 from darkgeem/master
Fixed latest versions of proxmark3 not working.
2026-04-06 15:02:35 +08:00
Self Not Found c72025787f Merge pull request #64 from Dmitry422/master
Edit instruction for MacOS users.
2026-04-06 15:00:36 +08:00
Darkgeem 784e627c0f Fixed latest versions of proxmark3 not working. 2025-12-11 01:16:35 +01:00
Dmitry422 9b175a4a93 Update README.md 2024-11-15 12:22:09 +07:00
Dmitry422 58d2ba4eae Update README.md 2024-11-15 12:21:38 +07:00
4 changed files with 27 additions and 36 deletions
+6 -6
View File
@@ -53,23 +53,21 @@ You can also download them in SourceForge
[![Download Proxmark3GUI](https://a.fsdn.com/con/app/sf-download-button)](https://sourceforge.net/projects/proxmark3gui/files/latest/download)
## Build on Linux
```bash
```
cd ~
# sudo add-apt-repository universe
sudo apt-get update
# sudo apt-get install git build-essential
sudo apt-get install qtbase5-dev qt5-qmake libqt5serialport5-dev
sudo apt-get install git build-essential
sudo apt-get install qt5-default libqt5serialport5-dev
git clone https://github.com/wh201906/Proxmark3GUI.git --depth=1
cd Proxmark3GUI
mkdir build && cd build
export QT_SELECT=qt5
qmake ../src
make -j4 && make clean
./Proxmark3GUI
```
## Build on macOS
```zsh
```
cd ~
brew update
brew install qt@5
@@ -84,6 +82,8 @@ open Proxmark3GUI.app
> In order for the GUI to connect to the device in macOS, you'd need to tweak the settings a little bit
Client Path must be path to pm3 console client like "/usr/local/bin/pm3/"
![macOS_settings](doc/README/macOS_settings.png)
***
+4 -6
View File
@@ -53,23 +53,21 @@ SourceForge平台上也可下载
[![Download Proxmark3GUI](https://a.fsdn.com/con/app/sf-download-button)](https://sourceforge.net/projects/proxmark3gui/files/latest/download)
## 在Linux系统下编译
```bash
```
cd ~
# sudo add-apt-repository universe
sudo apt-get update
# sudo apt-get install git build-essential
sudo apt-get install qtbase5-dev qt5-qmake libqt5serialport5-dev
sudo apt-get install git build-essential
sudo apt-get install qt5-default libqt5serialport5-dev
git clone https://github.com/wh201906/Proxmark3GUI.git --depth=1
cd Proxmark3GUI
mkdir build && cd build
export QT_SELECT=qt5
qmake ../src
make -j4 && make clean
./Proxmark3GUI
```
## 在macOS系统下编译
```zsh
```
cd ~
brew update
brew install qt@5
+17 -23
View File
@@ -22,6 +22,7 @@ void PM3Process::connectPM3(const QString& path, const QStringList args)
QString result;
Util::ClientType clientType;
setRequiringOutput(true);
QRegularExpression osPattern("(os:\\s+|OS\\.+\\s+)");
// stash for reconnect
currPath = path;
@@ -35,30 +36,35 @@ void PM3Process::connectPM3(const QString& path, const QStringList args)
waitForReadyRead(10000);
setRequiringOutput(false);
result = *requiredOutput;
// Workaround for wayland system, e.g. Ubuntu 22.04
// The issue is that the warning is read and nothing else, hence the process is killed.
if(result.contains("Warning: Ignoring XDG_SESSION_TYPE=wayland on Gnome. Use QT_QPA_PLATFORM=wayland to run on Wayland anyway."))
{
setRequiringOutput(true);
readWaitForConnection(&result);
}
if(result.contains("[=]"))
{
clientType = Util::CLIENTTYPE_ICEMAN;
setRequiringOutput(true);
write("hw version\n");
readWaitForConnection(&result);
for(int i = 0; i < 50; i++)
{
waitForReadyRead(200);
result += *requiredOutput;
// if(result.contains("os: "))
if(osPattern.match(result).hasMatch())
break;
}
setRequiringOutput(false);
}
else
{
clientType = Util::CLIENTTYPE_OFFICIAL;
}
if(result.contains("os: ")) // make sure the PM3 is connected
// if(result.contains("os: ")) // make sure the PM3 is connected
if(osPattern.match(result).hasMatch())
{
emit changeClientType(clientType);
result = result.mid(result.indexOf("os: "));
// result = result.mid(result.indexOf("os: "));
QRegularExpressionMatch osMatch = osPattern.match(result);
result = result.mid(osMatch.capturedStart());
result = result.left(result.indexOf("\n"));
result = result.mid(4, result.indexOf(" ", 4) - 4);
// result = result.mid(4, result.indexOf(" ", 4) - 4);
result = result.mid(osMatch.capturedLength(), result.indexOf(" ", osMatch.capturedLength()) - osMatch.capturedLength());
emit PM3StatedChanged(true, result);
}
else
@@ -72,18 +78,6 @@ void PM3Process::connectPM3(const QString& path, const QStringList args)
setRequiringOutput(false);
}
void PM3Process::readWaitForConnection(QString *result)
{
for(int i = 0; i < 50; i++)
{
waitForReadyRead(200);
(*result) += *requiredOutput;
if(result->contains("os: "))
break;
}
setRequiringOutput(false);
}
void PM3Process::reconnectPM3()
{
connectPM3(currPath, currArgs);
-1
View File
@@ -38,7 +38,6 @@ private:
bool isRequiringOutput;
QString* requiredOutput; // It only works in this class now
void setRequiringOutput(bool st);// It only works in this class now
void readWaitForConnection(QString *result);
QTimer* serialListener;
QSerialPortInfo* portInfo;
QString currPath;