Update in libtock-drivers/ and nfct_test.rs application

This commit is contained in:
Mirna
2020-10-12 13:31:06 +02:00
parent 0f6eeff486
commit 929aaf3ba2
3 changed files with 105 additions and 42 deletions

View File

@@ -925,9 +925,9 @@ if __name__ == "__main__":
"--nfct_test",
dest="application",
action="store_const",
const="console_test",
help=("Compiles and installs the console_test example that tests the "
"console driver with messages of various lengths."))
const="nfct_test",
help=("Compiles and installs the nfct_test example that tests the "
"NFC driver."))
main_parser.set_defaults(features=["with_ctap1"])

View File

@@ -4,6 +4,8 @@ use libtock_drivers::console::Console;
use libtock_drivers::nfc;
fn main(){
let mut console = Console::new();
writeln!(console, "****************************************").unwrap();
writeln!(console, "nfct_test application is installed").unwrap();
writeln!(console, "****************************************").unwrap();

View File

@@ -22,29 +22,29 @@ mod allow_nr {
pub const RECEIVE: usize = 2;
}
pub const TX_BUFFER_SIZE: usize = 256;
pub const RX_BUFFER_SIZE: usize = 256;
pub struct NfcTag {
tx_buffer: [u8; BUFFER_SIZE],
rx_buffer: [u8; BUFFER_SIZE],
tag_type: u8,
pub fn enable_emulation() {
emulate(true);
}
impl NfcTag {
pub fn new() -> Console {
Console {
tx_buffer: [0; TX_BUFFER_SIZE],
tx_buffer: [0; RX_BUFFER_SIZE],
tag_type: 0,
}
pub fn disable_emulation() {
emulate(false);
}
pub fn set_tag_type(&mut self, type: u8) {
self.tag_type = type;
pub fn emulate(enabled: bool) -> bool {
let result_code = syscalls::command(
DRIVER_NUMBER,
command_nr::EMULATE,
enabled as usize,
0
);
if result_code.is_err() {
return false;
}
pub fn selected(&self) -> bool {
true
}
pub fn selected() -> bool {
let is_selected = Cell::new(false);
let mut is_selected_alarm = || is_selected.set(true);
let subscription = syscalls::subscribe::<callback::Identity0Consumer, _>(
@@ -53,14 +53,75 @@ impl NfcTag {
&mut is_selected_alarm,
);
if subscription.is_err() {
return;
return false;
}
util::yieldk_for(|| is_selected.get());
true
}
pub fn receive(&self) {
pub fn configure(tag_type: u8) -> bool {
let result_code = syscalls::command(
DRIVER_NUMBER,
command_nr::CONFIGURE,
tag_type as usize,
0
);
if result_code.is_err() {
return false;
}
true
}
pub fn receive(buf: &mut [u8]) -> bool {
let result = syscalls::allow(DRIVER_NUMBER, allow_nr::RECEIVE, buf);
if result.is_err() {
return false;
}
let done = Cell::new(false);
let mut alarm = || done.set(true);
let subscription = syscalls::subscribe::<callback::Identity0Consumer, _>(
DRIVER_NUMBER,
subscribe_nr::RECEIVE,
&mut alarm,
);
if subscription.is_err() {
return false;
}
let result_code = syscalls::command(DRIVER_NUMBER, command_nr::RECEIVE, 0, 0);
if result_code.is_err() {
return false;
}
util::yieldk_for(|| done.get());
true
}
pub fn transmit(buf: &mut [u8]) -> bool {
let result = syscalls::allow(DRIVER_NUMBER, allow_nr::TRANSMIT, buf);
if result.is_err() {
return false;
}
let done = Cell::new(false);
let mut alarm = || done.set(true);
let subscription = syscalls::subscribe::<callback::Identity0Consumer, _>(
DRIVER_NUMBER,
subscribe_nr::TRANSMIT,
&mut alarm,
);
if subscription.is_err() {
return false;
}
let result_code = syscalls::command(DRIVER_NUMBER, command_nr::TRANSMIT, 0, 0);
if result_code.is_err() {
return false;
}
util::yieldk_for(|| done.get());
true
}