mirror of
https://github.com/silenty4ng/k5web
synced 2025-01-28 14:42:43 +00:00
Compare commits
No commits in common. "104fdb1f95038ff223bbaf0c483518824b142cd5" and "b5c8a6caaffee9fe39e8986654dba7bfba17f1d8" have entirely different histories.
104fdb1f95
...
b5c8a6caaf
2 changed files with 12 additions and 103 deletions
|
@ -953,74 +953,6 @@ async function readPacket(port, expectedData, timeout = 1000) {
|
|||
}
|
||||
|
||||
|
||||
/**
|
||||
* Waits for a packet from the radio. The packet data is returned as a Uint8Array.
|
||||
* @param {SerialPort} port - The serial port to read from.
|
||||
* @param {number} timeout - The timeout in milliseconds.
|
||||
* @returns {Promise<Uint8Array>} - A promise that resolves with the received packet or gets rejected on timeout.
|
||||
*/
|
||||
async function readPacketNoVerify(port, timeout = 1000) {
|
||||
// Create a reader to read data from the serial port
|
||||
const reader = port.readable.getReader();
|
||||
let buffer = new Uint8Array();
|
||||
let timeoutId; // Store the timeout ID to clear it later
|
||||
|
||||
try {
|
||||
return await new Promise((resolve, reject) => {
|
||||
// Event listener to handle incoming data
|
||||
function handleData({ value, done }) {
|
||||
if (done) {
|
||||
// If `done` is true, then the reader has been cancelled
|
||||
reject('Reader has been cancelled.');
|
||||
console.log('Reader has been cancelled. Current Buffer:', buffer, uint8ArrayToHexString(buffer));
|
||||
return;
|
||||
}
|
||||
|
||||
// Append the new data to the buffer
|
||||
buffer = new Uint8Array([...buffer, ...value]);
|
||||
|
||||
// Strip the beginning of the buffer until the first 0xAB byte
|
||||
// This is done to ensure that the buffer does not contain any incomplete packets
|
||||
while (buffer.length > 0 && buffer.indexOf(0xAB) != -1 && buffer.indexOf(0xCD) != -1) {
|
||||
resolve(true);
|
||||
return;
|
||||
}
|
||||
|
||||
// Continue reading data
|
||||
reader.read().then(handleData).catch(error => {
|
||||
console.error('Error reading data from the serial port:', error);
|
||||
reject(error);
|
||||
return;
|
||||
});
|
||||
}
|
||||
|
||||
// Subscribe to the data event to start listening for incoming data
|
||||
reader.read().then(handleData).catch(error_1 => {
|
||||
console.error('Error reading data from the serial port:', error_1);
|
||||
reject(error_1);
|
||||
return;
|
||||
});
|
||||
|
||||
// Set the timeout to reject the Promise if the packet is not received within the specified time
|
||||
timeoutId = setTimeout(() => {
|
||||
reader.cancel().then(() => {
|
||||
reject('Timeout: Packet not received within the specified time.');
|
||||
return;
|
||||
}).catch(error_2 => {
|
||||
console.error('Error cancelling reader:', error_2);
|
||||
reject(error_2);
|
||||
return;
|
||||
});
|
||||
}, timeout);
|
||||
});
|
||||
} finally {
|
||||
// Clear the timeout when the promise is settled (resolved or rejected)
|
||||
clearTimeout(timeoutId);
|
||||
// Release the reader in the finally block to ensure it is always released
|
||||
reader.releaseLock();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sends a packet to the radio.
|
||||
* @param {SerialPort} port - The serial port to write to.
|
||||
|
@ -1495,6 +1427,5 @@ export {
|
|||
flash_flashFirmware,
|
||||
flash_generateCommand,
|
||||
unpackVersion,
|
||||
unpack,
|
||||
readPacketNoVerify
|
||||
unpack
|
||||
}
|
|
@ -4,20 +4,10 @@
|
|||
<a-row :gutter="20" align="stretch">
|
||||
<a-col :span="24">
|
||||
<a-card class="general-card" :title="$t('menu.flash') + $t('global.onBoot')">
|
||||
<div style="display: flex; justify-content: space-between; align-items: center;">
|
||||
<div>
|
||||
<a-space>
|
||||
<a-button @click="selectFile">{{ state.binaryFile ? state.binaryName : $t('tool.selectFirmware') }}</a-button>
|
||||
<a-button type="primary" :disabled="!state.binaryFile" @click="flashIt">{{ $t('tool.flash') }}</a-button>
|
||||
</a-space>
|
||||
</div>
|
||||
<div>
|
||||
<a-radio-group type="button" size="mini" v-model="state.protocol">
|
||||
<a-radio value="Official">Official</a-radio>
|
||||
<a-radio value="Losehu">Losehu</a-radio>
|
||||
</a-radio-group>
|
||||
</div>
|
||||
</div>
|
||||
<a-space>
|
||||
<a-button @click="selectFile">{{ state.binaryFile ? state.binaryName : $t('tool.selectFirmware') }}</a-button>
|
||||
<a-button type="primary" :disabled="!state.binaryFile" @click="flashIt">{{ $t('tool.flash') }}</a-button>
|
||||
</a-space>
|
||||
<a-divider />
|
||||
<div id="statusArea" style="height: 20em; background-color: azure; color: silver; overflow: auto; padding: 20px"
|
||||
v-html="state.status"></div>
|
||||
|
@ -31,20 +21,18 @@
|
|||
import { reactive, nextTick, onMounted } from 'vue';
|
||||
import { useRoute } from 'vue-router';
|
||||
import { useAppStore } from '@/store';
|
||||
import { disconnect, connect, readPacket, sendPacket, unpackVersion, unpack, flash_generateCommand, readPacketNoVerify } from '@/utils/serial.js';
|
||||
import { disconnect, connect, readPacket, sendPacket, unpackVersion, unpack, flash_generateCommand } from '@/utils/serial.js';
|
||||
|
||||
const appStore = useAppStore();
|
||||
|
||||
const state : {
|
||||
status: any,
|
||||
binaryName: any,
|
||||
binaryFile: any,
|
||||
protocol: string
|
||||
binaryFile: any
|
||||
} = reactive({
|
||||
status: "点击更新按钮更新固件到设备<br/><br/>",
|
||||
binaryFile: undefined,
|
||||
binaryName: '',
|
||||
protocol: 'Official'
|
||||
binaryName: ''
|
||||
})
|
||||
|
||||
const route = useRoute();
|
||||
|
@ -90,17 +78,11 @@ const flashIt = async () => {
|
|||
await disconnect(appStore.connectPort);
|
||||
}
|
||||
let _connect = await connect();
|
||||
if(state.protocol == 'Official'){
|
||||
await readPacket(_connect, 0x18, 1000);
|
||||
}
|
||||
await readPacket(_connect, 0x18, 1000);
|
||||
const rawVersion = unpackVersion(state.binaryFile);
|
||||
const _data = new Uint8Array([0x30, 0x5, rawVersion.length, 0x0, ...rawVersion]);
|
||||
|
||||
if(state.protocol == 'Official'){
|
||||
await sendPacket(_connect, _data);
|
||||
await readPacket(_connect, 0x18);
|
||||
}
|
||||
|
||||
await sendPacket(_connect, _data);
|
||||
await readPacket(_connect, 0x18)
|
||||
const firmware = unpack(state.binaryFile);
|
||||
|
||||
if (firmware.length > 0xefff) throw new Error('Last resort boundary check failed. Whoever touched the code is an idiot.');
|
||||
|
@ -111,11 +93,7 @@ const flashIt = async () => {
|
|||
|
||||
try {
|
||||
await sendPacket(_connect, command);
|
||||
if(state.protocol == 'Official'){
|
||||
await readPacket(_connect, 0x1a);
|
||||
}else{
|
||||
await readPacketNoVerify(_connect);
|
||||
}
|
||||
await readPacket(_connect, 0x1a);
|
||||
} catch (e) {
|
||||
console.log('Flash command rejected. Aborting.');
|
||||
return Promise.reject(e);
|
||||
|
|
Loading…
Reference in a new issue