![]() |
LibDriver LLCC68
|
driver llcc68 header file More...
#include <stdio.h>#include <stdint.h>#include <string.h>Go to the source code of this file.
Data Structures | |
| struct | llcc68_handle_s |
| llcc68 handle structure definition More... | |
| struct | llcc68_info_s |
| llcc68 information structure definition More... | |
Macros | |
| #define | DRIVER_LLCC68_LINK_INIT(HANDLE, STRUCTURE) |
| initialize llcc68_handle_t structure | |
| #define | DRIVER_LLCC68_LINK_SPI_INIT(HANDLE, FUC) |
| link spi_init function | |
| #define | DRIVER_LLCC68_LINK_SPI_DEINIT(HANDLE, FUC) |
| link spi_deinit function | |
| #define | DRIVER_LLCC68_LINK_SPI_WRITE_READ(HANDLE, FUC) |
| link spi_write_read function | |
| #define | DRIVER_LLCC68_LINK_RESET_GPIO_INIT(HANDLE, FUC) |
| link reset_gpio_init function | |
| #define | DRIVER_LLCC68_LINK_RESET_GPIO_DEINIT(HANDLE, FUC) |
| link reset_gpio_deinit function | |
| #define | DRIVER_LLCC68_LINK_RESET_GPIO_WRITE(HANDLE, FUC) |
| link reset_gpio_write function | |
| #define | DRIVER_LLCC68_LINK_BUSY_GPIO_INIT(HANDLE, FUC) |
| link busy_gpio_init function | |
| #define | DRIVER_LLCC68_LINK_BUSY_GPIO_DEINIT(HANDLE, FUC) |
| link busy_gpio_deinit function | |
| #define | DRIVER_LLCC68_LINK_BUSY_GPIO_READ(HANDLE, FUC) |
| link busy_gpio_read function | |
| #define | DRIVER_LLCC68_LINK_DELAY_MS(HANDLE, FUC) |
| link delay_ms function | |
| #define | DRIVER_LLCC68_LINK_DEBUG_PRINT(HANDLE, FUC) |
| link debug_print function | |
| #define | DRIVER_LLCC68_LINK_RECEIVE_CALLBACK(HANDLE, FUC) |
| link receive_callback function | |
Typedefs | |
| typedef struct llcc68_handle_s | llcc68_handle_t |
| llcc68 handle structure definition | |
| typedef struct llcc68_info_s | llcc68_info_t |
| llcc68 information structure definition | |
Functions | |
| uint8_t | llcc68_info (llcc68_info_t *info) |
| get chip's information | |
| uint8_t | llcc68_irq_handler (llcc68_handle_t *handle) |
| irq handler | |
| uint8_t | llcc68_init (llcc68_handle_t *handle) |
| initialize the chip | |
| uint8_t | llcc68_deinit (llcc68_handle_t *handle) |
| close the chip | |
| uint8_t | llcc68_lora_transmit (llcc68_handle_t *handle, llcc68_clock_source_t standby_src, uint16_t preamble_length, llcc68_lora_header_t header_type, llcc68_lora_crc_type_t crc_type, llcc68_bool_t invert_iq_enable, uint8_t *buf, uint16_t len, uint32_t us) |
| send the lora data | |
| uint8_t | llcc68_lora_cad (llcc68_handle_t *handle, llcc68_bool_t *enable) |
| run the cad | |
| uint8_t | llcc68_single_receive (llcc68_handle_t *handle, double us) |
| enter to the single receive mode | |
| uint8_t | llcc68_continuous_receive (llcc68_handle_t *handle) |
| enter to the continuous receive mode | |
| uint8_t | llcc68_write_register (llcc68_handle_t *handle, uint16_t reg, uint8_t *buf, uint16_t len) |
| write the register | |
| uint8_t | llcc68_read_register (llcc68_handle_t *handle, uint16_t reg, uint8_t *buf, uint16_t len) |
| read the register | |
| uint8_t | llcc68_write_buffer (llcc68_handle_t *handle, uint8_t offset, uint8_t *buf, uint16_t len) |
| write the buffer | |
| uint8_t | llcc68_read_buffer (llcc68_handle_t *handle, uint8_t offset, uint8_t *buf, uint16_t len) |
| read the buffer | |
| uint8_t | llcc68_check_packet_error (llcc68_handle_t *handle, llcc68_bool_t *enable) |
| check the packet error | |
| uint8_t | llcc68_set_sleep (llcc68_handle_t *handle, llcc68_start_mode_t mode, llcc68_bool_t rtc_wake_up_enable) |
| enter to the sleep mode | |
| uint8_t | llcc68_set_standby (llcc68_handle_t *handle, llcc68_clock_source_t src) |
| enter to the standby mode | |
| uint8_t | llcc68_set_frequency_synthesis (llcc68_handle_t *handle) |
| enter to the frequency synthesis mode | |
| uint8_t | llcc68_set_tx (llcc68_handle_t *handle, uint32_t timeout) |
| enter to the tx mode | |
| uint8_t | llcc68_set_rx (llcc68_handle_t *handle, uint32_t timeout) |
| enter to the rx mode | |
| uint8_t | llcc68_timeout_convert_to_register (llcc68_handle_t *handle, double us, uint32_t *reg) |
| convert the timeout to the register raw data | |
| uint8_t | llcc68_timeout_convert_to_data (llcc68_handle_t *handle, uint32_t reg, double *us) |
| convert the register raw data to the timeout | |
| uint8_t | llcc68_set_stop_timer_on_preamble (llcc68_handle_t *handle, llcc68_bool_t enable) |
| stop timer on preamble | |
| uint8_t | llcc68_set_rx_duty_cycle (llcc68_handle_t *handle, uint32_t rx_period, uint32_t sleep_period) |
| set the rx duty cycle | |
| uint8_t | llcc68_set_cad (llcc68_handle_t *handle) |
| run the cad | |
| uint8_t | llcc68_set_tx_continuous_wave (llcc68_handle_t *handle) |
| enter to the tx continuous wave mode | |
| uint8_t | llcc68_set_tx_infinite_preamble (llcc68_handle_t *handle) |
| enter to the tx infinite preamble mode | |
| uint8_t | llcc68_set_regulator_mode (llcc68_handle_t *handle, llcc68_regulator_mode_t mode) |
| set the regulator_mode | |
| uint8_t | llcc68_set_calibration (llcc68_handle_t *handle, uint8_t settings) |
| set the calibration settings | |
| uint8_t | llcc68_set_calibration_image (llcc68_handle_t *handle, uint8_t freq1, uint8_t freq2) |
| set the calibration image frequency | |
| uint8_t | llcc68_set_pa_config (llcc68_handle_t *handle, uint8_t pa_duty_cycle, uint8_t hp_max) |
| set the pa config | |
| uint8_t | llcc68_set_rx_tx_fallback_mode (llcc68_handle_t *handle, llcc68_rx_tx_fallback_mode_t mode) |
| set the rx tx fallback mode | |
| uint8_t | llcc68_set_dio_irq_params (llcc68_handle_t *handle, uint16_t irq_mask, uint16_t dio1_mask, uint16_t dio2_mask, uint16_t dio3_mask) |
| set the dio irq params | |
| uint8_t | llcc68_get_irq_status (llcc68_handle_t *handle, uint16_t *status) |
| get the irq status | |
| uint8_t | llcc68_clear_irq_status (llcc68_handle_t *handle, uint16_t clear_irq_param) |
| clear the irq status | |
| uint8_t | llcc68_set_dio2_as_rf_switch_ctrl (llcc68_handle_t *handle, llcc68_bool_t enable) |
| set dio2 as rf switch ctrl | |
| uint8_t | llcc68_set_dio3_as_tcxo_ctrl (llcc68_handle_t *handle, llcc68_tcxo_voltage_t voltage, uint32_t delay) |
| set dio3 as tcxo ctrl | |
| uint8_t | llcc68_frequency_convert_to_register (llcc68_handle_t *handle, uint32_t freq, uint32_t *reg) |
| convert the frequency to the register raw data | |
| uint8_t | llcc68_frequency_convert_to_data (llcc68_handle_t *handle, uint32_t reg, uint32_t *freq) |
| convert the register raw data to the frequency | |
| uint8_t | llcc68_set_rf_frequency (llcc68_handle_t *handle, uint32_t reg) |
| set the rf frequency | |
| uint8_t | llcc68_set_packet_type (llcc68_handle_t *handle, llcc68_packet_type_t type) |
| set the packet type | |
| uint8_t | llcc68_get_packet_type (llcc68_handle_t *handle, llcc68_packet_type_t *type) |
| get the packet type | |
| uint8_t | llcc68_set_tx_params (llcc68_handle_t *handle, int8_t dbm, llcc68_ramp_time_t t) |
| set the tx params | |
| uint8_t | llcc68_set_gfsk_modulation_params (llcc68_handle_t *handle, uint32_t br, llcc68_gfsk_pulse_shape_t shape, llcc68_gfsk_bandwidth_t bw, uint32_t fdev) |
| set the modulation params in GFSK mode | |
| uint8_t | llcc68_gfsk_bit_rate_convert_to_register (llcc68_handle_t *handle, uint32_t br, uint32_t *reg) |
| convert the bit rate to the register raw data | |
| uint8_t | llcc68_gfsk_bit_rate_convert_to_data (llcc68_handle_t *handle, uint32_t reg, uint32_t *br) |
| convert the register raw data to the bit rate | |
| uint8_t | llcc68_gfsk_frequency_deviation_convert_to_register (llcc68_handle_t *handle, uint32_t freq, uint32_t *reg) |
| convert the frequency deviation to the register raw data | |
| uint8_t | llcc68_gfsk_frequency_deviation_convert_to_data (llcc68_handle_t *handle, uint32_t reg, uint32_t *freq) |
| convert the register raw data to the frequency deviation | |
| uint8_t | llcc68_set_lora_modulation_params (llcc68_handle_t *handle, llcc68_lora_sf_t sf, llcc68_lora_bandwidth_t bw, llcc68_lora_cr_t cr, llcc68_bool_t low_data_rate_optimize_enable) |
| set the modulation params in LoRa mode | |
| uint8_t | llcc68_set_gfsk_packet_params (llcc68_handle_t *handle, uint16_t preamble_length, llcc68_gfsk_preamble_detector_length_t detector_length, uint8_t sync_word_length, llcc68_gfsk_addr_filter_t filter, llcc68_gfsk_packet_type_t packet_type, uint8_t payload_length, llcc68_gfsk_crc_type_t crc_type, llcc68_bool_t whitening_enable) |
| set the packet params in GFSK mode | |
| uint8_t | llcc68_set_lora_packet_params (llcc68_handle_t *handle, uint16_t preamble_length, llcc68_lora_header_t header_type, uint8_t payload_length, llcc68_lora_crc_type_t crc_type, llcc68_bool_t invert_iq_enable) |
| set the packet params in LoRa mode | |
| uint8_t | llcc68_set_cad_params (llcc68_handle_t *handle, llcc68_lora_cad_symbol_num_t num, uint8_t cad_det_peak, uint8_t cad_det_min, llcc68_lora_cad_exit_mode_t mode, uint32_t timeout) |
| set the cad params | |
| uint8_t | llcc68_set_buffer_base_address (llcc68_handle_t *handle, uint8_t tx_base_addr, uint8_t rx_base_addr) |
| set the buffer base address | |
| uint8_t | llcc68_set_lora_symb_num_timeout (llcc68_handle_t *handle, uint8_t symb_num) |
| set the lora symbol number timeout | |
| uint8_t | llcc68_get_status (llcc68_handle_t *handle, uint8_t *status) |
| get the status | |
| uint8_t | llcc68_get_rx_buffer_status (llcc68_handle_t *handle, uint8_t *payload_length_rx, uint8_t *rx_start_buffer_pointer) |
| get the rx buffer status | |
| uint8_t | llcc68_get_gfsk_packet_status (llcc68_handle_t *handle, uint8_t *rx_status, uint8_t *rssi_sync_raw, uint8_t *rssi_avg_raw, float *rssi_sync, float *rssi_avg) |
| get the packet status in GFSK mode | |
| uint8_t | llcc68_get_lora_packet_status (llcc68_handle_t *handle, uint8_t *rssi_pkt_raw, int8_t *snr_pkt_raw, uint8_t *signal_rssi_pkt_raw, float *rssi_pkt, float *snr_pkt, float *signal_rssi_pkt) |
| get the packet status in LoRa mode | |
| uint8_t | llcc68_get_instantaneous_rssi (llcc68_handle_t *handle, uint8_t *rssi_inst_raw, float *rssi_inst) |
| get the instantaneous rssi | |
| uint8_t | llcc68_get_stats (llcc68_handle_t *handle, uint16_t *pkt_received, uint16_t *pkt_crc_error, uint16_t *pkt_length_header_error) |
| get the stats | |
| uint8_t | llcc68_reset_stats (llcc68_handle_t *handle, uint16_t pkt_received, uint16_t pkt_crc_error, uint16_t pkt_length_header_error) |
| reset the stats | |
| uint8_t | llcc68_get_device_errors (llcc68_handle_t *handle, uint16_t *op_error) |
| get the device errors | |
| uint8_t | llcc68_clear_device_errors (llcc68_handle_t *handle) |
| clear the device errors | |
| uint8_t | llcc68_set_fsk_whitening_initial_value (llcc68_handle_t *handle, uint16_t value) |
| set the whitening initial value in FSK mode | |
| uint8_t | llcc68_get_fsk_whitening_initial_value (llcc68_handle_t *handle, uint16_t *value) |
| get the whitening initial value in FSK mode | |
| uint8_t | llcc68_set_fsk_crc_initical_value (llcc68_handle_t *handle, uint16_t value) |
| set the crc initial value in FSK mode | |
| uint8_t | llcc68_get_fsk_crc_initical_value (llcc68_handle_t *handle, uint16_t *value) |
| get the crc initical value in FSK mode | |
| uint8_t | llcc68_set_fsk_crc_polynomial_value (llcc68_handle_t *handle, uint16_t value) |
| set the crc polynomial value in FSK mode | |
| uint8_t | llcc68_get_fsk_crc_polynomial_value (llcc68_handle_t *handle, uint16_t *value) |
| get the crc polynomial value in FSK mode | |
| uint8_t | llcc68_set_fsk_sync_word (llcc68_handle_t *handle, uint8_t sync_word[8]) |
| set the sync word in FSK mode | |
| uint8_t | llcc68_get_fsk_sync_word (llcc68_handle_t *handle, uint8_t sync_word[8]) |
| get the sync word in FSK mode | |
| uint8_t | llcc68_set_fsk_node_address (llcc68_handle_t *handle, uint8_t addr) |
| set the node address in FSK mode | |
| uint8_t | llcc68_get_fsk_node_address (llcc68_handle_t *handle, uint8_t *addr) |
| get the node address in FSK mode | |
| uint8_t | llcc68_set_fsk_broadcast_address (llcc68_handle_t *handle, uint8_t addr) |
| set the broadcast address in FSK mode | |
| uint8_t | llcc68_get_fsk_broadcast_address (llcc68_handle_t *handle, uint8_t *addr) |
| get the broadcast address in FSK mode | |
| uint8_t | llcc68_set_iq_polarity (llcc68_handle_t *handle, uint8_t setup) |
| set the iq polarity | |
| uint8_t | llcc68_get_iq_polarity (llcc68_handle_t *handle, uint8_t *setup) |
| get the iq polarity | |
| uint8_t | llcc68_set_lora_sync_word (llcc68_handle_t *handle, uint16_t sync_word) |
| set the lora sync word | |
| uint8_t | llcc68_get_lora_sync_word (llcc68_handle_t *handle, uint16_t *sync_word) |
| get the lora sync word | |
| uint8_t | llcc68_get_random_number (llcc68_handle_t *handle, uint32_t *r) |
| get the random number | |
| uint8_t | llcc68_set_tx_modulation (llcc68_handle_t *handle, uint8_t modulation) |
| set the tx modulation | |
| uint8_t | llcc68_get_tx_modulation (llcc68_handle_t *handle, uint8_t *modulation) |
| get the tx modulation | |
| uint8_t | llcc68_set_rx_gain (llcc68_handle_t *handle, uint8_t gain) |
| set the rx gain | |
| uint8_t | llcc68_get_rx_gain (llcc68_handle_t *handle, uint8_t *gain) |
| get the rx gain | |
| uint8_t | llcc68_set_tx_clamp_config (llcc68_handle_t *handle, uint8_t config) |
| set the tx clamp config | |
| uint8_t | llcc68_get_tx_clamp_config (llcc68_handle_t *handle, uint8_t *config) |
| get the tx clamp config | |
| uint8_t | llcc68_set_ocp (llcc68_handle_t *handle, uint8_t ocp) |
| set the ocp | |
| uint8_t | llcc68_get_ocp (llcc68_handle_t *handle, uint8_t *ocp) |
| get the ocp | |
| uint8_t | llcc68_set_rtc_control (llcc68_handle_t *handle, uint8_t control) |
| set the rtc control | |
| uint8_t | llcc68_get_rtc_control (llcc68_handle_t *handle, uint8_t *control) |
| get the rtc control | |
| uint8_t | llcc68_set_xta_trim (llcc68_handle_t *handle, uint8_t trim) |
| set the xta trim | |
| uint8_t | llcc68_get_xta_trim (llcc68_handle_t *handle, uint8_t *trim) |
| get the xta trim | |
| uint8_t | llcc68_set_xtb_trim (llcc68_handle_t *handle, uint8_t trim) |
| set the xtb trim | |
| uint8_t | llcc68_get_xtb_trim (llcc68_handle_t *handle, uint8_t *trim) |
| get the xtb trim | |
| uint8_t | llcc68_set_dio3_output_control (llcc68_handle_t *handle, uint8_t control) |
| set the dio3 output | |
| uint8_t | llcc68_get_dio3_output_control (llcc68_handle_t *handle, uint8_t *control) |
| get the dio3 output | |
| uint8_t | llcc68_set_event_mask (llcc68_handle_t *handle, uint8_t mask) |
| set the event mask | |
| uint8_t | llcc68_get_event_mask (llcc68_handle_t *handle, uint8_t *mask) |
| get the event mask | |
| uint8_t | llcc68_set_dio_output_enable (llcc68_handle_t *handle, uint8_t enable) |
| set the dio output enable | |
| uint8_t | llcc68_get_dio_output_enable (llcc68_handle_t *handle, uint8_t *enable) |
| get the dio output enable | |
| uint8_t | llcc68_set_dio_input_enable (llcc68_handle_t *handle, uint8_t enable) |
| set the dio input enable | |
| uint8_t | llcc68_get_dio_input_enable (llcc68_handle_t *handle, uint8_t *enable) |
| get the dio input enable | |
| uint8_t | llcc68_set_pull_up_control (llcc68_handle_t *handle, uint8_t control) |
| set the pull up control | |
| uint8_t | llcc68_get_pull_up_control (llcc68_handle_t *handle, uint8_t *control) |
| get the pull up control | |
| uint8_t | llcc68_set_pull_down_control (llcc68_handle_t *handle, uint8_t control) |
| set the pull down control | |
| uint8_t | llcc68_get_pull_down_control (llcc68_handle_t *handle, uint8_t *control) |
| get the pull down control | |
| uint8_t | llcc68_write_read_reg (llcc68_handle_t *handle, uint8_t *in_buf, uint32_t in_len, uint8_t *out_buf, uint32_t out_len) |
| write and read register | |
driver llcc68 header file
Copyright (c) 2015 - present LibDriver All rights reserved
The MIT License (MIT)
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
| Date | Version | Author | Description |
|---|---|---|---|
| 2023/04/15 | 1.0 | Shifeng Li | first upload |
Definition in file driver_llcc68.h.