Skip to content

Commit

Permalink
Initial piezo tests
Browse files Browse the repository at this point in the history
Somewhat promising (if noisy). LF coil + piezo simultaneously yields a notably stronger signal than either independently.
  • Loading branch information
zacharyweiss committed Feb 3, 2023
1 parent 83bd29d commit cb247c7
Show file tree
Hide file tree
Showing 6 changed files with 90 additions and 15 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Known bugs:

Emulation:
- [ ] Validate arha's bitmap changes, transition over to it fully
- [ ] Test piezo TX (prelim tests promising)
- [ ] General code cleanup
- [ ] Reverse track precompute & replay (should be simple with new bitmap approach; just iterate through bytes backwards, bits forwards?)
- [ ] Parameter tuning, find best defaults, troubleshoot improperly parsed TX
Expand Down
86 changes: 76 additions & 10 deletions helpers/mag_helpers.c
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,13 @@ void bitbang_raw(bool value, MagSetting* setting) {
case MagTxStateRFID:
furi_hal_gpio_write(RFID_PIN_OUT, value);
break;
case MagTxStateGPIOA6A7:
case MagTxStateGPIO:
furi_hal_gpio_write(GPIO_PIN_A, value);
furi_hal_gpio_write(GPIO_PIN_B, !value);
break;
case MagTxStatePiezo:
furi_hal_gpio_write(&gpio_speaker, value);
break;
case MagTxCC1101_434:
case MagTxCC1101_868:
if(last_value == 2 || value != (bool)last_value) {
Expand Down Expand Up @@ -90,15 +93,53 @@ void play_bit_gpio(uint8_t send_bit, MagSetting* setting) {
furi_delay_us(setting->us_interpacket);
}

void play_bit_piezo(uint8_t send_bit, MagSetting* setting) {
// TX testing with parasitic EMF from buzzer
bit_dir ^= 1;
furi_hal_gpio_write(&gpio_speaker, bit_dir);
furi_delay_us(setting->us_clock);

if(send_bit) {
bit_dir ^= 1;
furi_hal_gpio_write(&gpio_speaker, bit_dir);
}
furi_delay_us(setting->us_clock);

furi_delay_us(setting->us_interpacket);
}

void play_bit_lf_p(uint8_t send_bit, MagSetting* setting) {
// TX testing with parasitic EMF from buzzer
bit_dir ^= 1;
furi_hal_gpio_write(&gpio_speaker, bit_dir);
furi_hal_gpio_write(RFID_PIN_OUT, bit_dir);
furi_delay_us(setting->us_clock);

if(send_bit) {
bit_dir ^= 1;
furi_hal_gpio_write(&gpio_speaker, bit_dir);
furi_hal_gpio_write(RFID_PIN_OUT, bit_dir);
}
furi_delay_us(setting->us_clock);

furi_delay_us(setting->us_interpacket);
}

bool play_bit(uint8_t send_bit, MagSetting* setting) {
// Initialize configured TX method
switch(setting->tx) {
case MagTxStateRFID:
play_bit_rfid(send_bit, setting);
break;
case MagTxStateGPIOA6A7:
case MagTxStateGPIO:
play_bit_gpio(send_bit, setting);
break;
case MagTxStatePiezo:
play_bit_piezo(send_bit, setting);
break;
case MagTxStateLF_P:
play_bit_lf_p(send_bit, setting);
break;
case MagTxCC1101_434:
case MagTxCC1101_868:
play_bit_rf(send_bit & 0x01, setting);
Expand Down Expand Up @@ -185,15 +226,35 @@ void tx_deinit_rf() {
furi_hal_subghz_idle();
}

void tx_init_piezo() {
// TODO: some special mutex acquire procedure? c.f. furi_hal_speaker.c
furi_hal_gpio_init(&gpio_speaker, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);

// tossing in this delay arbitrarily to make it easier to see light blinking during TX
//furi_delay_ms(100);
}

void tx_deinit_piezo() {
// TODO: some special mutex release procedure?
furi_hal_gpio_init(&gpio_speaker, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
}

bool tx_init(MagSetting* setting) {
// Initialize configured TX method
switch(setting->tx) {
case MagTxStateRFID:
tx_init_rfid();
break;
case MagTxStateGPIOA6A7:
case MagTxStateGPIO:
tx_init_gpio();
break;
case MagTxStatePiezo:
tx_init_piezo();
break;
case MagTxStateLF_P:
tx_init_piezo();
tx_init_rfid();
break;
case MagTxCC1101_434:
tx_init_rf(434000000);
break;
Expand All @@ -213,9 +274,16 @@ bool tx_deinit(MagSetting* setting) {
case MagTxStateRFID:
tx_deinit_rfid();
break;
case MagTxStateGPIOA6A7:
case MagTxStateGPIO:
tx_deinit_gpio();
break;
case MagTxStatePiezo:
tx_deinit_piezo();
break;
case MagTxStateLF_P:
tx_deinit_piezo();
tx_deinit_rfid();
break;
case MagTxCC1101_434:
case MagTxCC1101_868:
tx_deinit_rf();
Expand Down Expand Up @@ -345,13 +413,11 @@ void mag_spoof_bitwise(Mag* mag) {
for(uint16_t i = 0; i < bits_t1_count; i++) {
uint8_t byte = i / 8;
uint8_t bitmask = 1 << (7 - (i % 8));
/* this comment is mostly for zw's convenience:
*
* bits are stored in their arrays like on a card (LSB first). This is not how usually bits are stored in a
/* Bits are stored in their arrays like on a card (LSB first). This is not how usually bits are stored in a
* byte, with the MSB first. the var bitmask creates the pattern to iterate through each bit, LSB first, like so
* 0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01, 0x80... masking bits one by one from the current byte
*
* i've chosen this LSB approach since bits and bytes are hard enough to visualize with the 5/8 and 7/8 encoding
* I've chosen this LSB approach since bits and bytes are hard enough to visualize with the 5/8 and 7/8 encoding
* MSR uses. It's a biiit more complicated to process, but visualizing it with printf or a debugger is
* infinitely easier
*
Expand All @@ -362,7 +428,7 @@ void mag_spoof_bitwise(Mag* mag) {
* bits backward, jumping 16 more bits ahead.
*
* I find this much more convenient for debugging, with the tiny incovenience of reading the bits in reverse
* order. THus, the reason for the bitmask above
* order. Thus, the reason for the bitmask above
*/

bit = !!(bits_t1_manchester[byte] & bitmask);
Expand Down Expand Up @@ -583,4 +649,4 @@ void debug_msr_string(char* data, uint8_t track_bits, uint8_t track_ascii_offset
if(i % 4 == 3) printf(" ");
}
printf("\r\n\r\n");
}
}
2 changes: 2 additions & 0 deletions helpers/mag_helpers.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

void play_bit_rfid(uint8_t send_bit, MagSetting* setting);
void play_bit_gpio(uint8_t send_bit, MagSetting* setting);
void play_bit_piezo(uint8_t send_bit, MagSetting* setting);
void play_bit_lf_p(uint8_t send_bit, MagSetting* setting);
bool play_bit(uint8_t send_bit, MagSetting* setting);
void tx_init_rfid();
void tx_init_gpio();
Expand Down
4 changes: 3 additions & 1 deletion helpers/mag_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,9 @@ typedef enum {

typedef enum {
MagTxStateRFID,
MagTxStateGPIOA6A7,
MagTxStateGPIO,
MagTxStatePiezo,
MagTxStateLF_P, // combo of RFID and Piezo
MagTxCC1101_434,
MagTxCC1101_868,
} MagTxState;
2 changes: 1 addition & 1 deletion mag.c
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

#define SETTING_DEFAULT_REVERSE MagReverseStateOff
#define SETTING_DEFAULT_TRACK MagTrackStateAll
#define SETTING_DEFAULT_TX_RFID MagTxStateRFID
#define SETTING_DEFAULT_TX_RFID MagTxStateGPIO
#define SETTING_DEFAULT_US_CLOCK 240
#define SETTING_DEFAULT_US_INTERPACKET 10

Expand Down
10 changes: 7 additions & 3 deletions scenes/mag_scene_emulate_config.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,16 +10,20 @@ enum MagSettingIndex {
MagSettingIndexInterpacket,
};

#define TX_COUNT 4
#define TX_COUNT 6
const char* const tx_text[TX_COUNT] = {
"RFID",
"A6/A7",
"GPIO",
"Piezo",
"LF+P",
"434MHz",
"868MHz",
};
const uint32_t tx_value[TX_COUNT] = {
MagTxStateRFID,
MagTxStateGPIOA6A7,
MagTxStateGPIO,
MagTxStatePiezo,
MagTxStateLF_P,
MagTxCC1101_434,
MagTxCC1101_868,

Expand Down

0 comments on commit cb247c7

Please sign in to comment.