亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? nrf24l01.c

?? 介紹NRF24L01的多通道(Multiple Pipes),其中文件nrf24l01.c實現此射頻芯片在多通道下的通信
?? C
?? 第 1 頁 / 共 3 頁
字號:
/******************************************************************************
*
* File: nrf24l01.c
* 
* Copyright S. Brennen Ball, 2006-2007
* 
* The author provides no guarantees, warantees, or promises, implied or
*	otherwise.  By using this software you agree to indemnify the author
* 	of any damages incurred by using it.
*
*****************************************************************************/

#include "nrf24l01.h"

//Arguments except opt_rx_standby_mode fill the actual register they are named 
//  after. Registers that do not need to be initialized are not included here.
//The argument opt_rx_active_mode is only used if the user is initializing the
//  24L01 as a receiver.  If the argument is false, the receiver will remain in
//  standby mode and not monitor for packets.  If the argument is true, the CE
//  pin will be set and the 24L01 will monitor for packets.  In TX mode, the value
//  of this argument is insignificant.
//If the user wants to leave any 1-byte register in its default state, simply put
//  as that register's argument nrf24l01_<reg>_DEFAULT_VAL, where <reg> is the register
//  name.
//If the user wants to leave any of the 5-byte registers RX_ADDR_P0, RX_ADDR_P1, or 
//  TX_ADDR in its default state, simply put NULL in the argument for that address value.
void nrf24l01_initialize(unsigned char config,
						 unsigned char opt_rx_active_mode,  
						 unsigned char en_aa, 
						 unsigned char en_rxaddr, 
						 unsigned char setup_aw, 
						 unsigned char setup_retr, 
						 unsigned char rf_ch, 
						 unsigned char rf_setup, 
						 unsigned char * rx_addr_p0, 
						 unsigned char * rx_addr_p1, 
						 unsigned char rx_addr_p2, 
						 unsigned char rx_addr_p3, 
						 unsigned char rx_addr_p4, 
						 unsigned char rx_addr_p5, 
						 unsigned char * tx_addr, 
						 unsigned char rx_pw_p0, 
						 unsigned char rx_pw_p1, 
						 unsigned char rx_pw_p2, 
						 unsigned char rx_pw_p3, 
						 unsigned char rx_pw_p4, 
						 unsigned char rx_pw_p5)
{
	unsigned char data[5];

	data[0] = en_aa;
	nrf24l01_write_register(nrf24l01_EN_AA, data, 1);

	data[0] = en_rxaddr;
	nrf24l01_write_register(nrf24l01_EN_RXADDR, data, 1);

	data[0] = setup_aw;
	nrf24l01_write_register(nrf24l01_SETUP_AW, data, 1);

	data[0] = setup_retr;
	nrf24l01_write_register(nrf24l01_SETUP_RETR, data, 1);

	data[0] = rf_ch;
	nrf24l01_write_register(nrf24l01_RF_CH, data, 1);

	data[0] = rf_setup;
	nrf24l01_write_register(nrf24l01_RF_SETUP, data, 1);

	if(rx_addr_p0 != NULL)
		nrf24l01_set_rx_addr(rx_addr_p0, 5, 0);
	else
	{
		data[0] = nrf24l01_RX_ADDR_P0_B0_DEFAULT_VAL;
		data[1] = nrf24l01_RX_ADDR_P0_B1_DEFAULT_VAL;
		data[2] = nrf24l01_RX_ADDR_P0_B2_DEFAULT_VAL;
		data[3] = nrf24l01_RX_ADDR_P0_B3_DEFAULT_VAL;
		data[4] = nrf24l01_RX_ADDR_P0_B4_DEFAULT_VAL;
		
		nrf24l01_set_rx_addr(data, 5, 0);
	}

	if(rx_addr_p1 != NULL)
		nrf24l01_set_rx_addr(rx_addr_p1, 5, 1);
	else
	{
		data[0] = nrf24l01_RX_ADDR_P1_B0_DEFAULT_VAL;
		data[1] = nrf24l01_RX_ADDR_P1_B1_DEFAULT_VAL;
		data[2] = nrf24l01_RX_ADDR_P1_B2_DEFAULT_VAL;
		data[3] = nrf24l01_RX_ADDR_P1_B3_DEFAULT_VAL;
		data[4] = nrf24l01_RX_ADDR_P1_B4_DEFAULT_VAL;
		
		nrf24l01_set_rx_addr(data, 5, 1);
	}

	data[0] = rx_addr_p2;
	nrf24l01_set_rx_addr(data, 1, 2);

	data[0] = rx_addr_p3;
	nrf24l01_set_rx_addr(data, 1, 3);

	data[0] = rx_addr_p4;
	nrf24l01_set_rx_addr(data, 1, 4);

	data[0] = rx_addr_p5;
	nrf24l01_set_rx_addr(data, 1, 5);

	if(tx_addr != NULL)
		nrf24l01_set_tx_addr(tx_addr, 5);
	else
	{
		data[0] = nrf24l01_TX_ADDR_B0_DEFAULT_VAL;
		data[1] = nrf24l01_TX_ADDR_B1_DEFAULT_VAL;
		data[2] = nrf24l01_TX_ADDR_B2_DEFAULT_VAL;
		data[3] = nrf24l01_TX_ADDR_B3_DEFAULT_VAL;
		data[4] = nrf24l01_TX_ADDR_B4_DEFAULT_VAL;
		
		nrf24l01_set_tx_addr(data, 5);
	}

	data[0] = rx_pw_p0;
	nrf24l01_write_register(nrf24l01_RX_PW_P0, data, 1);

	data[0] = rx_pw_p1;
	nrf24l01_write_register(nrf24l01_RX_PW_P1, data, 1);

	data[0] = rx_pw_p2;
	nrf24l01_write_register(nrf24l01_RX_PW_P2, data, 1);

	data[0] = rx_pw_p3;
	nrf24l01_write_register(nrf24l01_RX_PW_P3, data, 1);

	data[0] = rx_pw_p4;
	nrf24l01_write_register(nrf24l01_RX_PW_P4, data, 1);

	data[0] = rx_pw_p5;
	nrf24l01_write_register(nrf24l01_RX_PW_P5, data, 1);

	if((config & nrf24l01_CONFIG_PWR_UP) != 0)
		nrf24l01_power_up_param(opt_rx_active_mode, config);
	else
		nrf24l01_power_down_param(config);
}

//initializes the 24L01 to all default values except the PWR_UP and PRIM_RX bits
//this function also disables the auto-ack feature on the chip (EN_AA register is 0)
//bool rx is true if the device should be a receiver and false if it should be
//  a transmitter.
//unsigned char payload_width is the payload width for pipe 0.  All other pipes
//  are left in their default (disabled) state.
//bool enable_auto_ack controls the auto ack feature on pipe 0.  If true, auto-ack will
//  be enabled.  If false, auto-ack is disabled.
void nrf24l01_initialize_debug(bool rx, unsigned char p0_payload_width, bool enable_auto_ack)
{
	unsigned char config;
	unsigned char en_aa;
	
	config = nrf24l01_CONFIG_DEFAULT_VAL | nrf24l01_CONFIG_PWR_UP;
	
	if(enable_auto_ack != false)
		en_aa = nrf24l01_EN_AA_ENAA_P0;
	else
		en_aa = nrf24l01_EN_AA_ENAA_NONE;
	
	if(rx == true)
		config = config | nrf24l01_CONFIG_PRIM_RX;
		
	nrf24l01_initialize(config, 
						true,
						en_aa, 
						nrf24l01_EN_RXADDR_DEFAULT_VAL, 
						nrf24l01_SETUP_AW_DEFAULT_VAL, 
						nrf24l01_SETUP_RETR_DEFAULT_VAL, 
						nrf24l01_RF_CH_DEFAULT_VAL, 
						nrf24l01_RF_SETUP_DEFAULT_VAL,  
						NULL, 
						NULL, 
						nrf24l01_RX_ADDR_P2_DEFAULT_VAL, 
						nrf24l01_RX_ADDR_P3_DEFAULT_VAL, 
						nrf24l01_RX_ADDR_P4_DEFAULT_VAL, 
						nrf24l01_RX_ADDR_P5_DEFAULT_VAL, 
						NULL, 
						p0_payload_width, 
						nrf24l01_RX_PW_P1_DEFAULT_VAL, 
						nrf24l01_RX_PW_P2_DEFAULT_VAL, 
						nrf24l01_RX_PW_P3_DEFAULT_VAL, 
						nrf24l01_RX_PW_P4_DEFAULT_VAL, 
						nrf24l01_RX_PW_P5_DEFAULT_VAL);
}

//initializes only the CONFIG register and pipe 0's payload width
//the primary purpose of this function is to allow users with microcontrollers with
//  extremely small program memories to still be able to init their 24L01.  This code
//  should have a smaller footprint than the above init functions.
//when using this method, the 24L01 MUST have its default configuration loaded
//  in all registers to work.  It is recommended that the device be reset or
//  have its power cycled immediately before this code is run.
//in normal circumstances, the user should use nrf24l01_initialize() rather than this
//  function, since this function does not set all of the register values.
void nrf24l01_initialize_debug_lite(bool rx, unsigned char p0_payload_width)
{
	unsigned char config;
	
	config = nrf24l01_CONFIG_DEFAULT_VAL;
	
	if(rx != false)
		config |= nrf24l01_CONFIG_PRIM_RX;
		
	nrf24l01_write_register(nrf24l01_RX_PW_P0, &p0_payload_width, 1);
	nrf24l01_power_up_param(true, config);
}

//powers up the 24L01 with all necessary delays
//this function takes the existing contents of the CONFIG register and sets the PWR_UP 
//the argument rx_active_mode is only used if the user is setting up the
//  24L01 as a receiver.  If the argument is false, the receiver will remain in
//  standby mode and not monitor for packets.  If the argument is true, the CE
//  pin will be set and the 24L01 will monitor for packets.  In TX mode, the value
//  of this argument is insignificant.
//note: if the read value of the CONFIG register already has the PWR_UP bit set, this function
//  exits in order to not make an unecessary register write.
void nrf24l01_power_up(bool rx_active_mode)
{
	unsigned char config;
	
	nrf24l01_read_register(nrf24l01_CONFIG, &config, 1);
	
	if((config & nrf24l01_CONFIG_PWR_UP) != 0)
		return;
		
	config |= nrf24l01_CONFIG_PWR_UP;
	
	nrf24l01_write_register(nrf24l01_CONFIG, &config, 1);
	
	delay_us(1500);
	
	if((config & nrf24l01_CONFIG_PRIM_RX) == 0)
		nrf24l01_clear_ce();
	else
	{
		if(rx_active_mode != false)
			nrf24l01_set_ce();
		else
			nrf24l01_clear_ce();
	}
}

//powers up the 24L01 with all necessary delays
//this function allows the user to set the contents of the CONFIG register, but the function
//  sets the PWR_UP bit in the CONFIG register, so the user does not need to.
//the argument rx_active_mode is only used if the user is setting up the
//  24L01 as a receiver.  If the argument is false, the receiver will remain in
//  standby mode and not monitor for packets.  If the argument is true, the CE
//  pin will be set and the 24L01 will monitor for packets.  In TX mode, the value
//  of this argument is insignificant.
void nrf24l01_power_up_param(bool rx_active_mode, unsigned char config)
{
	unsigned char test, test2;
	
	config |= nrf24l01_CONFIG_PWR_UP;
	
	nrf24l01_write_register(nrf24l01_CONFIG, &config, 1);

	delay_us(1500);

	if((config & nrf24l01_CONFIG_PRIM_RX) == 0)
		nrf24l01_clear_ce();
	else
	{
		if(rx_active_mode != false)
			nrf24l01_set_ce();
		else
			nrf24l01_clear_ce();
	}
}

//powers down the 24L01
//this function takes the existing contents of the CONFIG register and simply
//  clears the PWR_UP bit in the CONFIG register.
//note: if the read value of the CONFIG register already has the PWR_UP bit cleared, this 
//  function exits in order to not make an unecessary register write.
void nrf24l01_power_down()
{
	unsigned char config;
	
	nrf24l01_read_register(nrf24l01_CONFIG, &config, 1);
	
	if((config & nrf24l01_CONFIG_PWR_UP) == 0)
		return;
	
	config &= (~nrf24l01_CONFIG_PWR_UP);
	
	nrf24l01_write_register(nrf24l01_CONFIG, &config, 1);

	nrf24l01_clear_ce();
}

//powers down the 24L01
//this function allows the user to set the contents of the CONFIG register, but the function
//  clears the PWR_UP bit in the CONFIG register, so the user does not need to.
void nrf24l01_power_down_param(unsigned char config)
{
	config &= (~nrf24l01_CONFIG_PWR_UP);
	
	nrf24l01_write_register(nrf24l01_CONFIG, &config, 1);

	nrf24l01_clear_ce();
}


//sets up the 24L01 as a receiver with all necessary delays
//this function takes the existing contents of the CONFIG register and sets the PRIM_RX 
//  bit in the CONFIG register.
//if the argument rx_active_mode is false, the receiver will remain in standby mode
//  and not monitor for packets.  If the argument is true, the CE pin will be set 
//  and the 24L01 will monitor for packets.
//note: if the read value of the CONFIG register already has the PRIM_RX bit set, this function
//  exits in order to not make an unecessary register write.
void nrf24l01_set_as_rx(bool rx_active_mode)
{
	unsigned char config;
	unsigned char status;
	
	status = nrf24l01_read_register(0, &config, 1);

	if((config & nrf24l01_CONFIG_PRIM_RX) != 0)
		return;

	config |= nrf24l01_CONFIG_PRIM_RX;
	
	nrf24l01_write_register(nrf24l01_CONFIG, &config, 1);

	if(rx_active_mode != false)
		nrf24l01_set_ce();
	else
		nrf24l01_clear_ce();
}

//sets up the 24L01 as a receiver with all necessary delays
//this function allows the user to set the contents of the CONFIG register, but the function
//  sets the PRIM_RX bit in the CONFIG register, so the user does not need to.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一二三区在线观看| 久久久久一区二区三区四区| 亚洲美女免费在线| 色国产综合视频| 亚洲第一搞黄网站| 日韩欧美成人激情| 成人丝袜18视频在线观看| 亚洲欧美在线aaa| 国产99久久久久久免费看农村| 免费不卡在线视频| 99天天综合性| 久久国产婷婷国产香蕉| 久久精品国产99久久6| 亚洲在线一区二区三区| 国产精品一区一区| 青娱乐精品视频| 日本不卡免费在线视频| 91精品国产一区二区| 欧美一区二区久久| 国产精品456| 亚洲综合一二区| 精品国产一区a| 99久久精品国产导航| 三级不卡在线观看| 日本一区二区三区免费乱视频 | 成人激情动漫在线观看| 亚洲欧洲在线观看av| 欧美日韩国产一级片| 国产剧情在线观看一区二区| 亚洲精品乱码久久久久久黑人| 91精品国产综合久久久久久久| 成人午夜av影视| 91九色02白丝porn| 精品一区二区三区免费| 亚洲蜜桃精久久久久久久| 日韩精品自拍偷拍| 91在线无精精品入口| 久久91精品久久久久久秒播 | 亚洲人成人一区二区在线观看| 欧美无砖专区一中文字| 国产激情精品久久久第一区二区| 亚洲与欧洲av电影| 国产精品天美传媒| 日韩午夜av电影| 91久久精品一区二区三区| 久久精品国产久精国产爱| 亚洲免费av在线| 国产午夜精品理论片a级大结局| 欧美性xxxxxxxx| av一区二区久久| 激情综合色播五月| 视频一区视频二区中文| 亚洲人成人一区二区在线观看| 久久久久国产一区二区三区四区 | 99久久精品国产导航| 久久成人18免费观看| 亚洲国产精品一区二区久久恐怖片| 久久久精品tv| 日韩小视频在线观看专区| 欧美亚洲国产一区在线观看网站 | 欧美亚洲综合在线| 99精品欧美一区二区三区综合在线| 狠狠色2019综合网| 美美哒免费高清在线观看视频一区二区| 夜夜嗨av一区二区三区| 亚洲欧美一区二区在线观看| 久久精品人人做| 久久久久久久综合| 久久伊人蜜桃av一区二区| 日韩欧美国产一区二区三区 | 亚洲精品日日夜夜| 国产精品久久久久久久久晋中| 国产喂奶挤奶一区二区三区| 精品国产亚洲在线| 欧美videofree性高清杂交| 日韩午夜小视频| 91精品国产一区二区人妖| 69p69国产精品| 欧美一区二区免费视频| 日韩欧美国产麻豆| 久久综合九色综合久久久精品综合| 日韩精品中文字幕一区| 日韩欧美一区中文| 欧美精品一区二区三区一线天视频| 日韩欧美亚洲另类制服综合在线| 日本欧美大码aⅴ在线播放| 亚洲福利电影网| 免费观看日韩av| 国产激情91久久精品导航| 风间由美中文字幕在线看视频国产欧美| 国产91丝袜在线播放0| 成人国产一区二区三区精品| av网站免费线看精品| www.成人在线| 在线观看成人免费视频| 欧美日韩国产综合一区二区 | 精品国产乱码久久久久久老虎| 久久久噜噜噜久噜久久综合| 国产精品麻豆一区二区| 一区二区三区免费在线观看| 天天操天天色综合| 国产一区二区91| 成人app软件下载大全免费| 色狠狠桃花综合| 欧美成人精品福利| 中文字幕一区二区三区乱码在线 | 亚洲欧美色一区| 日韩av在线发布| 成人涩涩免费视频| 欧美色图天堂网| 久久久亚洲综合| 一区二区三区日韩精品视频| 老司机免费视频一区二区| www.欧美日韩| 日韩午夜激情免费电影| 亚洲欧洲99久久| 久久99精品一区二区三区| 91麻豆.com| 精品国产123| 一卡二卡欧美日韩| 国产美女主播视频一区| 欧美自拍偷拍午夜视频| 欧美精品一区二区三区在线播放 | 亚洲人成7777| 九九**精品视频免费播放| 91免费版在线| 久久久精品人体av艺术| 亚洲二区在线观看| 99久久99久久精品免费观看| 日韩三级精品电影久久久| 亚洲另类在线制服丝袜| 国产精品一区二区在线播放| 欧美久久久久久久久久| 国产精品亲子伦对白| 麻豆精品久久久| 欧美日韩一区 二区 三区 久久精品| 久久久久久久一区| 毛片av一区二区三区| 在线观看成人免费视频| 亚洲欧洲另类国产综合| 精品一区精品二区高清| 欧美精三区欧美精三区| 亚洲人成精品久久久久久| 国产精品中文字幕日韩精品| 欧美精品123区| 亚洲成人动漫在线免费观看| 99久久精品免费| 国产欧美中文在线| 国产另类ts人妖一区二区| 亚洲成va人在线观看| 色猫猫国产区一区二在线视频| 欧美高清在线一区| 国产大片一区二区| 精品电影一区二区| 久久成人免费日本黄色| 欧美一区二区三区在线观看| 亚洲一二三四在线观看| 一本大道久久a久久综合| 成人欧美一区二区三区在线播放| 国产精品一区二区男女羞羞无遮挡| 日韩免费在线观看| 青娱乐精品视频在线| 日韩一区二区三区电影在线观看| 香蕉成人伊视频在线观看| 欧美日韩日日骚| 五月综合激情日本mⅴ| 欧美精品精品一区| 男人的天堂久久精品| 欧美大片在线观看一区二区| 奇米777欧美一区二区| 精品国产一区二区精华| 国产在线观看免费一区| 久久亚洲二区三区| 国产精品综合一区二区三区| 国产欧美日韩不卡免费| 丰满少妇在线播放bd日韩电影| 国产精品美女一区二区| 97se亚洲国产综合自在线观| 一区二区三区在线免费观看| 欧美亚洲国产一区二区三区| 日本最新不卡在线| 欧美成人bangbros| 国产91在线观看| 一区二区三区免费网站| 91精品国产高清一区二区三区| 久久电影网电视剧免费观看| 国产欧美精品一区二区色综合| 成人av免费网站| 亚洲成人激情社区| 日韩免费高清av| 国产精品18久久久久久vr| 中文字幕一区三区| 欧美精品精品一区| 日韩一区二区三区视频在线| 国产河南妇女毛片精品久久久| 国产精品的网站| 欧美另类一区二区三区| 国产乱理伦片在线观看夜一区| 亚洲免费在线看| 欧美疯狂做受xxxx富婆|