回复
发帖数: 25
注册日期: ‎04-20-2017

Si1064/si4455功率配置

想实现用官网的si1064平台实现在同一个工程实现配置不同功率大小的载波,但是在实际编写测试程序的过程中出现了一个非常奇怪的问题:现将部分代码张贴如下,完整的工程文件见附件。

首先利用WDS软件生成2种不同的功率的radio_config.h,将有关RF参数的分别放到2个不同的数组,供测试调用,生成的radio_config.h中关键代码以及修改后的如下: 

radio_config.h

//RF_WRITE_TX_FIFO  实现915MHz 0.94dBm的未调制载波POWER0
#define RF_WRITE_TX_FIFO_POWER0 0x66, 0x9B, 0x5D, 0x41, 0xDE, 0xC2, 0x68, 0xF6, 0x2E, 0x27, 0x31, 0x5E, 0xE9, 0x91, 0xD1, 0x81, 0xA0, 0xCC, 0x58, 0x5C, \
0xF8, 0xE5, 0x8A, 0x06, 0x41, 0x59, 0xD8, 0x23, 0xB9, 0xA8, 0x45, 0x4C, 0x9C, 0x16, 0x38, 0x1F, 0x7E, 0xE3, 0x5F, 0xC5, \
0x93, 0x0E, 0x5B, 0xCD, 0xC6, 0x13, 0xF1, 0x93, 0xE8, 0xFC, 0x79, 0x3F, 0x29, 0x06, 0x89, 0x29, 0x1D, 0x19, 0x71, 0x9E, \
0x29, 0x43, 0x38, 0x2A, 0x21, 0x4F, 0x3D, 0x54, 0x26, 0x27, 0x03, 0xDC, 0x64, 0x36, 0xC5, 0x03, 0x36, 0xB7, 0x1F, 0xC4, \
0x9A, 0xC5, 0xC3, 0x3A, 0x97, 0x53, 0x90, 0x2E, 0x21, 0xD6, 0x18, 0x76, 0x8E, 0xEC, 0x89, 0x97, 0xA2, 0x2E, 0x2C, 0x89, \
0x68, 0xEB, 0x48, 0x3C, 0x6F, 0x0F, 0xB3, 0xDD, 0xCC, 0x67, 0x60, 0x37, 0x9F, 0xEC
#define RF_WRITE_TX_FIFO_1_POWER0 0x66, 0x67, 0x7A, 0xED, 0x22, 0xB3, 0x18, 0x10, 0x13, 0xF0, 0x7C, 0x7F, 0x85, 0x19, 0x7B, 0xC1, 0xFE, 0xA9, 0xD3, 0xDB, \
0xC2, 0xB1, 0x05, 0xFB, 0xD9, 0xFE, 0x91, 0xE6, 0xE5, 0x1C, 0x26, 0x78, 0x12, 0x63, 0x13, 0xCF, 0xA9, 0x99, 0x84, 0xEF, \
0x77, 0x9B, 0x42, 0x78, 0x61, 0x5D, 0xA0, 0xA8, 0xF1, 0xEE, 0xCF, 0xCA, 0xE9, 0xC1, 0xD8, 0xF0, 0x0D, 0x05, 0x14, 0xC3, \
0x0C, 0xAC, 0xEE, 0x29, 0x6A, 0x87, 0x49, 0x0E, 0x6A, 0x55, 0xA5, 0x86, 0x31, 0xBA, 0x1B, 0x63, 0xEE, 0x2A, 0xB0, 0xFC, \
0x5C, 0xCE, 0x44, 0x9A, 0x33, 0xF1, 0xAD, 0x61, 0x59, 0x9E, 0xBA, 0x60, 0x43, 0x9D, 0xA3, 0x2A, 0xA1, 0x37, 0x16, 0x6C, \
0xE2, 0x2A, 0x98, 0x0C, 0x8C, 0x02, 0x0F, 0x8B, 0xEC, 0x5A, 0x93, 0x10

#define RF_EZCONFIG_CHECK_POWER0 0x19, 0x92, 0x44

 

//RF_WRITE_TX_FIFO 实现915MHz 0.94dBm的未调制载波POWER1
#define RF_WRITE_TX_FIFO_POWER1 0x66, 0xBE, 0x80, 0x8C, 0xBB, 0x38, 0x2A, 0x6C, 0xF4, 0xAB, 0xC0, 0x56, 0xF0, 0xFB, 0xF2, 0x32, 0xCC, 0x0D, 0xB9, 0x9C, \
0x34, 0xCD, 0xD2, 0x2A, 0x7C, 0x39, 0x1F, 0xF4, 0xD9, 0x10, 0x9F, 0x0C, 0xC5, 0x4A, 0x2C, 0xAF, 0xA0, 0x8E, 0xF0, 0x49, \
0x5F, 0x8D, 0xFC, 0x19, 0xE5, 0x24, 0x8F, 0x2C, 0x6B, 0x72, 0x5E, 0xCA, 0xC6, 0x5F, 0x37, 0x7B, 0x79, 0xA2, 0xB3, 0x8E, \
0xC0, 0x59, 0x17, 0x98, 0x66, 0x78, 0x18, 0x34, 0xB1, 0x10, 0xC5, 0xF9, 0x21, 0x70, 0xC0, 0x89, 0x18, 0x66, 0x14, 0x1D, \
0x70, 0x6A, 0x5D, 0x90, 0x2C, 0x36, 0x5D, 0xDB, 0xB1, 0x82, 0x86, 0xC5, 0x6C, 0x03, 0xA2, 0x05, 0x32, 0x2B, 0x51, 0x9A, \
0x03, 0xF7, 0x75, 0xFC, 0x68, 0x92, 0xE9, 0x4C, 0x79, 0xB9, 0x13, 0xDC, 0xCF, 0x76
#define RF_WRITE_TX_FIFO_1_POWER1 0x66, 0xD1, 0x9E, 0x02, 0x1D, 0x59, 0xE0, 0x73, 0x49, 0x66, 0xD4, 0xF7, 0x46, 0xA0, 0x68, 0x74, 0x2A, 0x7B, 0xC7, 0x4F, \
0xCE, 0xE8, 0xF2, 0x10, 0x91, 0x3E, 0xAB, 0xF0, 0x01, 0x33, 0x93, 0x22, 0x73, 0xF6, 0x21, 0x1B, 0xF4, 0xA0, 0xDC, 0xA5, \
0x1E, 0x51, 0x82, 0x4E, 0x55, 0x5D, 0x1B, 0x31, 0x3E, 0x13, 0x6C, 0x04, 0x8B, 0x2C, 0xF0, 0x6E, 0xB5, 0xD8, 0x49, 0xCC, \
0xE0, 0xEA, 0x1D, 0x9D, 0xF8, 0x55, 0xCA, 0xED, 0x26, 0xB8, 0x69, 0x40, 0x0D, 0xA6, 0xD7, 0x80, 0x03, 0x04, 0x30, 0x14, \
0x25, 0xAD, 0x18, 0x12, 0xCB, 0xDD, 0x50, 0x8B, 0x2E, 0xD0, 0x2C, 0xB0, 0xDB, 0x28, 0x4B, 0xED, 0x46, 0xFD, 0xF2, 0x88, \
0xE2, 0x72, 0x44, 0x11, 0x00, 0x62, 0x6E, 0x82, 0x96, 0x7C, 0x5E, 0x6C
#define RF_EZCONFIG_CHECK_POWER1 0x19, 0x6D, 0xE7

2种不同功率的数组和结构体宏定义

#define RADIO_CONFIGURATION_DATA_ARRAY_POWER0 { \
0x07, RF_POWER_UP, \
0x05, RF_INT_CTL_ENABLE_1, \
0x08, RF_FRR_CTL_A_MODE_4, \
0x05, RF_EZCONFIG_XO_TUNE_1, \
0x72, RF_WRITE_TX_FIFO_POWER0, \
0x01, RF_NOP, \
0x70, RF_WRITE_TX_FIFO_1_POWER0, \
0x03, RF_EZCONFIG_CHECK_POWER0, \
0x08, RF_GPIO_PIN_CFG, \
0x00 \
}

#define RADIO_CONFIGURATION_DATA_ARRAY_POWER1 { \
0x07, RF_POWER_UP, \
0x05, RF_INT_CTL_ENABLE_1, \
0x08, RF_FRR_CTL_A_MODE_4, \
0x05, RF_EZCONFIG_XO_TUNE_1, \
0x72, RF_WRITE_TX_FIFO_POWER1, \
0x01, RF_NOP, \
0x70, RF_WRITE_TX_FIFO_1_POWER1, \
0x03, RF_EZCONFIG_CHECK_POWER1, \
0x08, RF_GPIO_PIN_CFG, \
0x00 \
}

#define RADIO_CONFIGURATION_DATA_POWER0 { \
Radio_Configuration_Data_Array_POWER0, \
RADIO_CONFIGURATION_DATA_CHANNEL_NUMBER, \
RADIO_CONFIGURATION_DATA_RADIO_PACKET_LENGTH, \
RADIO_CONFIGURATION_DATA_RADIO_STATE_AFTER_POWER_UP, \
RADIO_CONFIGURATION_DATA_RADIO_DELAY_CNT_AFTER_RESET \
}

#define RADIO_CONFIGURATION_DATA_POWER1 { \
Radio_Configuration_Data_Array_POWER1, \
RADIO_CONFIGURATION_DATA_CHANNEL_NUMBER, \
RADIO_CONFIGURATION_DATA_RADIO_PACKET_LENGTH, \
RADIO_CONFIGURATION_DATA_RADIO_STATE_AFTER_POWER_UP, \
RADIO_CONFIGURATION_DATA_RADIO_DELAY_CNT_AFTER_RESET \
}

 

程序1:输出Power0的未调制载波

在radio_config.h做好相应修改之后,接着在radio.c中做了如下修改

const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER0[], U8, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_ARRAY_POWER0;//数组

const SEGMENT_VARIABLE(RadioConfiguration0, tRadioConfiguration, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_POWER0;//结构体

const SEGMENT_VARIABLE_SEGMENT_POINTER(p0RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE) = \
&RadioConfiguration0;//指针

 

在radio.h 修改如下:

extern const SEGMENT_VARIABLE_SEGMENT_POINTER(p0RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE);

extern const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER0[], U8, SEG_CODE);

 

程序调用 实现radio_config.h的功率POWER0输出:

/* Load radio configuration *///
while (SI4455_SUCCESS != si4455_configuration_init(p0RadioConfiguration->Radio_ConfigurationArray))

main.c call the fuctions

// Start Transmitting CW
vRadio_StartTx(p0RadioConfiguration->Radio_ChannelNumber, NULL);

结果:程序能正常编译,Si1064开发板能够实现POWER0的功率输出

 

程序2:输出Power1的未调制载波

在radio_config.h做好相应修改之后,接着在radio.c中做了如下修改

const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER1[], U8, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_ARRAY_POWER1;//数组

const SEGMENT_VARIABLE(RadioConfiguration1, tRadioConfiguration, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_POWER1;//结构体

const SEGMENT_VARIABLE_SEGMENT_POINTER(p1RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE) = \
&RadioConfiguration1;//指针

 

在radio.h 修改如下:

extern const SEGMENT_VARIABLE_SEGMENT_POINTER(p1RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE);

extern const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER1[], U8, SEG_CODE);

 

程序调用 实现radio_config.h的功率POWER1输出:

/* Load radio configuration *///
while (SI4455_SUCCESS != si4455_configuration_init(p1RadioConfiguration->Radio_ConfigurationArray))

main.c call the fuctions

// Start Transmitting CW
vRadio_StartTx(p1RadioConfiguration->Radio_ChannelNumber, NULL);

结果:程序能正常编译,Si1064开发板能够实现POWER1的功率输出

 

程序3:

在radio.c中做了如下修改.Radio_config.h不做任何修改

//POWER0

const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER0[], U8, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_ARRAY_POWER0;//数组

const SEGMENT_VARIABLE(RadioConfiguration0, tRadioConfiguration, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_POWER0;//结构体

const SEGMENT_VARIABLE_SEGMENT_POINTER(p0RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE) = \
&RadioConfiguration0;//指针

 

//POWER1

const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER1[], U8, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_ARRAY_POWER1;//数组

const SEGMENT_VARIABLE(RadioConfiguration1, tRadioConfiguration, SEG_CODE) = \
RADIO_CONFIGURATION_DATA_POWER1;//结构体

const SEGMENT_VARIABLE_SEGMENT_POINTER(p0RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE) = \
&RadioConfiguration1;//指针

在radio.h 修改如下:

//POWER0

extern const SEGMENT_VARIABLE_SEGMENT_POINTER(p0RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE);

extern const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER0[], U8, SEG_CODE);

//POWER1

extern const SEGMENT_VARIABLE_SEGMENT_POINTER(p1RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE);

extern const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER1[], U8, SEG_CODE);

 

程序调用 依然实现radio_config.h的功率POWER1输出(这里只是把POWER0和POWER1的宏在radio.c都添加):

/* Load radio configuration *///
while (SI4455_SUCCESS != si4455_configuration_init(p1RadioConfiguration->Radio_ConfigurationArray))

main.c call the fuctions

// Start Transmitting CW
vRadio_StartTx(p1RadioConfiguration->Radio_ChannelNumber, NULL);

结果:程序能正常编译通过,Si1064开发板程序却木有正常执行,程序一直卡在SMBUS中断不执行

void vSmbus_SMBusStop()
{
/* Stop SMBus transaction */
STO = TRUE;
SI = FALSE;
while (STO == TRUE);//S1064开发板调试一直卡在这里
}

 

结论:我在radio.c单独声明定义Power0或者Power1的数组,结构体,指针,程序都可以正常执行,在radio.C中同时声明定义,但是还是只调用输出一种功率时,程序能正常编译通过,但是却木有输出,硬件调试时一直卡在SMBUS中断,实在是太奇怪了,已经连续弄了5天,依然木有找到问题,程序的逻辑完全是正常的,希望大神指点。

 

发帖数: 72
注册日期: ‎12-02-2016

回复: Si1064/si4455功率配置

1. 你提供的程序跟上面的描述存在一定的差异,初步看了一下并未发现什么异常,如果可以,请提供一份最新的程序并附带详细描述;

2. 上面所述程序1、2中均未提及smbus,而程序3中提到了smbus,但是主程序中并未看到相关smbus的调用程序,所以请说明是radio未有输出还是smbus出问题了。

 

Regards,

Yongsheng

发帖数: 25
注册日期: ‎04-20-2017

回复: Si1064/si4455功率配置

Yongsheng老师,您好:

首先非常感谢老师在百忙之中抽空回答,我的测试平台依旧是Si1064 915Mhz的Silicon LABS的开发平台,

工程是基于WDS的915Mhz的未调制载波,想对载波的功率进行按需配置,附件为我目前测试的工程。

  

老师可以按照如下方法测试:

 1.直接打开工程,编译环境Silicon Labs IDE。

    测试结果:编译通过,木有任何错误,也木有任何载波输出,开发板硬件调试时,跳到SMBUS中断。

 

2.测试完成1后,老师可以屏蔽注释掉radio.c文件中的power0的cost定义的数组,结构体,指针,即可

/*********************************POWER0配置:对应的数组,结构体,指针************************************************************/
const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER0[], U8, SEG_CODE) = \
              RADIO_CONFIGURATION_DATA_ARRAY_POWER0;

const SEGMENT_VARIABLE(RadioConfiguration0, tRadioConfiguration, SEG_CODE) = \
              RADIO_CONFIGURATION_DATA_POWER0;

const SEGMENT_VARIABLE_SEGMENT_POINTER(p0RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE) = \
                        &RadioConfiguration0;
/**********************************************************************************************/

测试结果:编译通过,开发板输出915Mhz POWER1功率的载波

 

3.测试完成2后,老师可以将2中的power0的cost定义的数组,结构体,指针,这3个部分取消注释,将Power1的cost定义的数组,结构体,指针,这3个部分进行屏蔽注释,再将有关

p1RadioConfiguration的指针改为
p0RadioConfiguration
/**********************************POWER1配置:对应的数组,结构体,指针************************************************************/
const SEGMENT_VARIABLE(Radio_Configuration_Data_Array_POWER1[], U8, SEG_CODE) = \
              RADIO_CONFIGURATION_DATA_ARRAY_POWER1;

const SEGMENT_VARIABLE(RadioConfiguration1, tRadioConfiguration, SEG_CODE) = \
              RADIO_CONFIGURATION_DATA_POWER1;

const SEGMENT_VARIABLE_SEGMENT_POINTER(p1RadioConfiguration, tRadioConfiguration, SEG_CODE, SEG_CODE) = \
                        &RadioConfiguration1;

将p1RadioConfiguration-》p0RadioConfiguration

 设计到的修改函数为radio.c里的 1.vRadio_PowerUp(void) 2.void vRadio_Init(void)

                                 main.c里的  vRadio_StartTx(p1RadioConfiguration->Radio_ChannelNumber, NULL);的指针名

测试结果:编译通过,开发板输出915Mhz POWER0功率的载波

 

 

老师可以按照以上步骤测试,我用的是官网的开发板,这几天一直纠结这个问题:

现总结如下问题:

1.在工程中定义某个全局变量,如果不用,会导致程序运行不正常,也就是跑飞:

  例:老师可以在main.c里的main函数前随便定义一个U8 POWER_level的全局变量,就会导致程序运行不正常,这非常奇怪

2.在main.c添加某一个中断函数,程序会一直卡在硬件初始化,哪怕你木有去调用它,非常奇怪

例:我在main.c的main函数前:

void vPlf_McuInit (void);
void vInitializeHW (void);
INTERRUPT_PROTO (PCA0_ISR, INTERRUPT_PCA0);//添加测试

 

在程序末尾,也就是main函数末尾:添加以下中断函数,

INTERRUPT(PCA0_ISR, INTERRUPT_PCA0)
{
//static unsigned int current_capture_value, previous_capture_value;
//static unsigned int capture_period;
static unsigned long current_capture_value, previous_capture_value;
static unsigned long capture_period;


if (CCF0) // If Module 0 caused the interrupt
{
CCF0 = 0; // Clear module 0 interrupt flag.

// Store most recent capture value
current_capture_value = PCA0CP0;

// Calculate capture period from last two values.
capture_period = current_capture_value - previous_capture_value;

// Update previous capture value with most recent info.
previous_capture_value = current_capture_value;

}
else // Interrupt was caused by other bits.
{
PCA0CN &= ~0x86; // Clear other interrupt flags for PCA
}
}

测试结果:开发板硬件调试,卡在: vInitializeHW();

 

还是非常感谢老师抽出宝贵时间解答,但是这些问题真的非常奇怪,老师如果方便,学生希望老师留下您的Email或者其他联系方式,谢谢您!

 

Benjamin

Thanks

发帖数: 72
注册日期: ‎12-02-2016

回复: Si1064/si4455功率配置

我在DK板上测试了你提供的程序,没有很刻意的单独定义测试,而是把radio_config.h、radio.h、radio.c中定义的POWER0和POWER1参数全都不屏蔽,测试的结果是,无论初始默认配置POWER0或者POWER1,之后的radio输出都没有问题。但是,有一点请注意,当你屏蔽了在radio.c中定义的POWER0或者POWER1参数,请把radio_config.h中引用了这些参数的对应POWER0或POWER1的定义给屏蔽掉,虽然编译并没出错,但是严格地讲,如果引用了未定义的参数,是不对的。 总体上,程序没什么严重的问题。

 

所以,主要原因可能是你的板子有问题,请仔细仿真跟踪一下。

 

至于email地址,很抱歉不方便提供给你,因为这边的工作方式是如果客户有问题,除了在论坛上提交的问题,一般不能直接找AE处理。正常流程是先找代理商FAE解决,如解决不了,代理商会跟原厂联络,交给原厂的FAE或者AE解决。

 

Regards,

Yongsheng

发帖数: 25
注册日期: ‎04-20-2017

回复: Si1064/si4455功率配置

老师:

    你说我的开发板有问题,我目前觉得不可能啊,我现在想确定的是,老师,你用的DK开发板是Si1064-915-DK开发板嘛,我上传的那个工程,在我的开发板是木有输出啊,但是按照我的那个写的测试教程来做的话,我分别只定义POWER0,POWER1的时候,开发板的radio是有输出的,同时定义的时候是木有的,这实在是太奇怪了,我一直觉得我的程序逻辑是木有问题的,但是程序执行起来不正常,老师请您确认一下这个现象,非常谢谢老师的回答!

Benjamin

Thanks

发帖数: 72
注册日期: ‎12-02-2016

Re: Si1064/si4455功率配置

Hi,

可能是你的keil不太匹配,请安装keil c51 v9.53或者以前的版本, 新版本的KEIL支持会有问题,我们之前有遇到过。

 

Regards,

Yongsheng

发帖数: 25
注册日期: ‎04-20-2017

Re: Si1064/si4455功率配置

谢谢Yongsheng老师:

            确实是你说的那个样纸,只能使用keil c51 v9.53以前的版本,这个问题困扰了我2周时间,建议写入Si1064的datasheet中,新版本的keil编译器会影响代码的编译,导致程序运行不正常。非常感谢YongSheng老师。

         老师现在发现一个新的问题,我用Si1064-915-DK开发板参照silicon Labs官网给的例程写了一个Si064_PCA0_Capture_Input工程,由于si1064木有官方例程,是在wds生成的CW工程中添加的F930的PCA0_Capture_Input代码,P01输出500us方波,P00输入捕获,P01与P00连接,

        现象:P01输出500us的方波正常,但是P01的PCA中断只触发了一次,

                 硬件调试时:WATCH窗口0x0759,而不是F930中例程中的0x32(50)

        疑点:Si1064是不是不支持PCA0_Capture_Input,因为我看到Si1060的例程中也木有                PCA0_Capture_Input.c例程文件,很奇怪

         现附上工程,杜邦线连接P00和P01即可,希望老师帮忙解决!

Benjamin

 Thanks

 

发帖数: 72
注册日期: ‎12-02-2016

Re: Si1064/si4455功率配置

Hi,

关于MCU部分的问题,请查阅si1064的datasheet和reference manual以及application note,  或者新建case请MCU Team的帮忙处理。

 

Regards,

Yongsheng