fix bootrom using new names (but still old packets)

This commit is contained in:
Philippe Teuwen 2019-04-25 01:53:00 +02:00
parent 4b5800d78f
commit 7d2d23ce50
2 changed files with 44 additions and 15 deletions

View file

@ -8,8 +8,7 @@
# DO NOT use thumb mode in the phase 1 bootloader since that generates a section with glue code # DO NOT use thumb mode in the phase 1 bootloader since that generates a section with glue code
ARMSRC = ARMSRC =
THUMBSRC = cmd.c \ THUMBSRC = usb_cdc.c \
usb_cdc.c \
bootrom.c bootrom.c
ASMSRC = ram-reset.s flash-reset.s ASMSRC = ram-reset.s flash-reset.s

View file

@ -8,13 +8,40 @@
#include <proxmark3.h> #include <proxmark3.h>
#include "usb_cdc.h" #include "usb_cdc.h"
#include "cmd.h"
struct common_area common_area __attribute__((section(".commonarea"))); struct common_area common_area __attribute__((section(".commonarea")));
unsigned int start_addr, end_addr, bootrom_unlocked; unsigned int start_addr, end_addr, bootrom_unlocked;
extern char _bootrom_start, _bootrom_end, _flash_start, _flash_end; extern char _bootrom_start, _bootrom_end, _flash_start, _flash_end;
extern uint32_t _osimage_entry; extern uint32_t _osimage_entry;
static int reply_old(uint64_t cmd, uint64_t arg0, uint64_t arg1, uint64_t arg2, void *data, size_t len) {
PacketResponseOLD txcmd;
for (size_t i = 0; i < sizeof(PacketResponseOLD); i++)
((uint8_t *)&txcmd)[i] = 0x00;
// Compose the outgoing command frame
txcmd.cmd = cmd;
txcmd.arg[0] = arg0;
txcmd.arg[1] = arg1;
txcmd.arg[2] = arg2;
// Add the (optional) content to the frame, with a maximum size of USB_CMD_DATA_SIZE
if (data && len) {
len = MIN(len, USB_CMD_DATA_SIZE);
for (size_t i = 0; i < len; i++) {
txcmd.d.asBytes[i] = ((uint8_t *)data)[i];
}
}
int result = PM3_EUNDEF;
// Send frame and make sure all bytes are transmitted
result = usb_write((uint8_t *)&txcmd, sizeof(PacketResponseOLD));
return result;
}
void DbpString(char *str) { void DbpString(char *str) {
uint8_t len = 0; uint8_t len = 0;
while (str[len] != 0x00) while (str[len] != 0x00)
@ -84,13 +111,16 @@ static void Fatal(void) {
for (;;) {}; for (;;) {};
} }
void PacketReceived(PacketCommandNG *packet) { void UsbPacketReceived(uint8_t *packet, int len) {
int i, dont_ack = 0; int i, dont_ack = 0;
PacketCommandOLD *c = (PacketCommandOLD *)packet;
volatile uint32_t *p; volatile uint32_t *p;
uint32_t arg0 = (uint32_t)packet->oldarg[0]; //if ( len != sizeof(PacketCommandOLD`)) Fatal();
switch (packet->cmd) { uint32_t arg0 = (uint32_t)c->arg[0];
switch (c->cmd) {
case CMD_DEVICE_INFO: { case CMD_DEVICE_INFO: {
dont_ack = 1; dont_ack = 1;
arg0 = DEVICE_INFO_FLAG_BOOTROM_PRESENT | DEVICE_INFO_FLAG_CURRENT_MODE_BOOTROM | arg0 = DEVICE_INFO_FLAG_BOOTROM_PRESENT | DEVICE_INFO_FLAG_CURRENT_MODE_BOOTROM |
@ -108,7 +138,7 @@ void PacketReceived(PacketCommandNG *packet) {
*/ */
p = (volatile uint32_t *)&_flash_start; p = (volatile uint32_t *)&_flash_start;
for (i = 0; i < 12; i++) for (i = 0; i < 12; i++)
p[i + arg0] = packet->data.asDwords[i]; p[i + arg0] = c->d.asDwords[i];
} }
break; break;
@ -116,7 +146,7 @@ void PacketReceived(PacketCommandNG *packet) {
uint32_t *flash_mem = (uint32_t *)(&_flash_start); uint32_t *flash_mem = (uint32_t *)(&_flash_start);
for (int j = 0; j < 2; j++) { for (int j = 0; j < 2; j++) {
for (i = 0 + (64 * j); i < 64 + (64 * j); i++) { for (i = 0 + (64 * j); i < 64 + (64 * j); i++) {
flash_mem[i] = packet->data.asDwords[i]; flash_mem[i] = c->d.asDwords[i];
} }
uint32_t flash_address = arg0 + (0x100 * j); uint32_t flash_address = arg0 + (0x100 * j);
@ -152,7 +182,7 @@ void PacketReceived(PacketCommandNG *packet) {
break; break;
case CMD_START_FLASH: { case CMD_START_FLASH: {
if (packet->oldarg[2] == START_FLASH_MAGIC) if (c->arg[2] == START_FLASH_MAGIC)
bootrom_unlocked = 1; bootrom_unlocked = 1;
else else
bootrom_unlocked = 0; bootrom_unlocked = 0;
@ -161,8 +191,8 @@ void PacketReceived(PacketCommandNG *packet) {
int prot_end = (int)&_bootrom_end; int prot_end = (int)&_bootrom_end;
int allow_start = (int)&_flash_start; int allow_start = (int)&_flash_start;
int allow_end = (int)&_flash_end; int allow_end = (int)&_flash_end;
int cmd_start = packet->oldarg[0]; int cmd_start = c->arg[0];
int cmd_end = packet->oldarg[1]; int cmd_end = c->arg[1];
/* Only allow command if the bootrom is unlocked, or the parameters are outside of the protected /* Only allow command if the bootrom is unlocked, or the parameters are outside of the protected
* bootrom area. In any case they must be within the flash area. * bootrom area. In any case they must be within the flash area.
@ -194,7 +224,7 @@ static void flash_mode(int externally_entered) {
start_addr = 0; start_addr = 0;
end_addr = 0; end_addr = 0;
bootrom_unlocked = 0; bootrom_unlocked = 0;
PacketCommandNG rx; uint8_t rx[sizeof(PacketCommandOLD)];
usb_enable(); usb_enable();
@ -206,9 +236,9 @@ static void flash_mode(int externally_entered) {
// Check if there is a usb packet available // Check if there is a usb packet available
if (usb_poll_validate_length()) { if (usb_poll_validate_length()) {
// TODO DOEGOX if (usb_read(rx, sizeof(rx))) {
if (usb_read((uint8_t *)&rx, sizeof(rx))) UsbPacketReceived(rx, sizeof(rx));
PacketReceived(&rx); }
} }
if (!externally_entered && !BUTTON_PRESS()) { if (!externally_entered && !BUTTON_PRESS()) {