?? 2.txt
字號:
/****************************************************************************
*
* MODULE: WSN - Router
*
* COMPONENT: $RCSfile: WSN_Router.c,v $
*
* VERSION: $Name: $
*
* REVISION: $Revision: 1.4 $
*
* DATED: $Date: 2006/12/11 10:38:48 $
*
* STATUS: $State: Exp $
*
* AUTHOR: IDM
*
* DESCRIPTION:
*
* Implements a Wireless Sensor Network Router using the Jennic Zigbee stack.
* Reads temperature, humidity and battery voltage and transmits these to
* network coordinator. Assumes code is running on a evaluation kit sensor
* board.
*
* LAST MODIFIED BY: $Author: imorr $
* $Modtime: $
*
****************************************************************************
*
* This software is owned by Jennic and/or its supplier and is protected
* under applicable copyright laws. All rights are reserved. We grant You,
* and any third parties, a license to use this software solely and
* exclusively on Jennic products. You, and any third parties must reproduce
* the copyright and warranty notice and any other legend of ownership on each
* copy or partial copy of the software.
*
* THIS SOFTWARE IS PROVIDED "AS IS". JENNIC MAKES NO WARRANTIES, WHETHER
* EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE,
* ACCURACY OR LACK OF NEGLIGENCE. JENNIC SHALL NOT, IN ANY CIRCUMSTANCES,
* BE LIABLE FOR ANY DAMAGES, INCLUDING, BUT NOT LIMITED TO, SPECIAL,
* INCIDENTAL OR CONSEQUENTIAL DAMAGES FOR ANY REASON WHATSOEVER.
*
* Copyright Jennic Ltd 2005, 2006. All rights reserved
*
****************************************************************************/
/****************************************************************************/
/*** Include files ***/
/****************************************************************************/
#include <jendefs.h>
#include <ALSdriver.h>
#include <HTSdriver.h>
#include <LedControl.h>
#include <AppHardwareApi.h>
#include <JZ_Api.h>
#include "WSN_Profile.h"
/****************************************************************************/
/*** Macro Definitions ***/
/****************************************************************************/
/* Timing values */
#define APP_TICK_PERIOD_ms 100
#define APP_TICK_PERIOD (APP_TICK_PERIOD_ms * 32)
#define APP_DATA_SEND_PERIOD_ms 1000
#define APP_DATA_SEND_PERIOD (APP_DATA_SEND_PERIOD_ms / APP_TICK_PERIOD_ms)
/****************************************************************************/
/*** Type Definitions ***/
/****************************************************************************/
/* Battery reading state definitions */
typedef enum
{
E_STATE_READ_BATT_VOLT_IDLE,
E_STATE_READ_BATT_VOLTS_ADC_CONVERTING,
E_STATE_READ_BATT_VOLTS_COMPLETE,
E_STATE_READ_BATT_VOLTS_READY
}teStateReadBattVolt;
/* Temperature/Humidity Sensor - reading state definitions */
typedef enum
{
E_STATE_READ_TEMP_HUMID_IDLE,
E_STATE_READ_HUMID_RUNNING,
E_STATE_READ_TEMP_HUMID_COMPLETE,
E_STATE_READ_TEMP_START,
E_STATE_READ_TEMP_HUMID_RUNNING,
E_STATE_READ_TEMP_COMPLETE,
E_STATE_READ_TEMP_HUMID_READY
}teStateReadTempHumidity;
/* Battery measurement data */
typedef struct
{
uint16 u16Reading;
teStateReadBattVolt eState;
}tsBattSensor;
/* Temp/Humidity measurement data */
typedef struct
{
uint16 u16TempReading;
uint16 u16HumidReading;
teStateReadTempHumidity eState;
}tsTempHumiditySensor;
/****************************************************************************/
/*** Local Function Prototypes ***/
/****************************************************************************/
PRIVATE void vInit(void);
PRIVATE void vSendData(void);
PRIVATE void vInitSensors(void);
PRIVATE void vReadTempHumidity(void);
PRIVATE void vReadBatteryVoltage(void);
PRIVATE void vAppTick(void *pvMsg, uint8 u8Param);
/****************************************************************************/
/*** Local Variables ***/
/****************************************************************************/
PRIVATE uint8 u8AppTicks = 0;
PRIVATE tsBattSensor sBattSensor;
PRIVATE tsTempHumiditySensor sTempHumiditySensor;
PRIVATE bool_t bAppTimerStarted = FALSE;
PRIVATE bool_t bNwkJoined = FALSE;
/****************************************************************************
*
* NAME: AppColdStart
*
* DESCRIPTION:
* Entry point for application. Initialises system, starts scan then
* processes interrupts.
*
* RETURNS:
* void, never returns
*
****************************************************************************/
PUBLIC void AppColdStart(void)
{
/* General initialisation: reset hardware */
JZS_sConfig.u32Channel = WSN_CHANNEL;
JZS_sConfig.u16PanId = WSN_PAN_ID;
/* General initialisation: reset hardware */
vInit();
/* No return from the above function call */
}
/****************************************************************************
*
* NAME: AppWarmStart
*
* DESCRIPTION:
* Entry point for application from boot loader. Simply jumps to AppColdStart
* as, in this instance, application will never warm start.
*
* RETURNS:
* Never returns.
*
****************************************************************************/
PUBLIC void AppWarmStart(void)
{
AppColdStart();
}
/****************************************************************************/
/*** Local Functions ***/
/****************************************************************************/
/****************************************************************************
*
* NAME: vInit
*
* DESCRIPTION:
* Initialises Zigbee stack and hardware. Final action is to start BOS, from
* which there is no return. Subsequent application actions occur in the
* functions defined above.
*
* RETURNS:
* No return from this function
*
****************************************************************************/
PRIVATE void vInit(void)
{
/* Initialise Zigbee stack */
JZS_u32InitSystem(TRUE);
/* Set DIO for LEDs */
vLedInitRfd();
vLedControl(0,0);
vLedControl(1,0);
/* Set sensors */
vInitSensors();
/* Start BOS */
(void)bBosRun(TRUE);
/* No return from the above function call */
}
/****************************************************************************
*
* NAME: vInitSensors
*
* DESCRIPTION:
* Initialise the temperature/humidity sensor and set the ADC to measure the
* supply voltage.
*
****************************************************************************/
PRIVATE void vInitSensors(void)
{
/* Initialise temp/humidity sensor interface */
vHTSreset();
sTempHumiditySensor.eState = E_STATE_READ_TEMP_HUMID_IDLE;
/* Initialise ADC for internal battery voltage measurement */
sBattSensor.eState = E_STATE_READ_BATT_VOLT_IDLE;
vAHI_ApConfigure(E_AHI_AP_REGULATOR_ENABLE,
E_AHI_AP_INT_DISABLE,
E_AHI_AP_SAMPLE_2,
E_AHI_AP_CLOCKDIV_2MHZ,
E_AHI_AP_INTREF);
/* Wait until the analogue peripheral regulator has come up before setting
the ADC. */
while(!bAHI_APRegulatorEnabled());
vAHI_AdcEnable(E_AHI_ADC_CONVERT_DISABLE,
E_AHI_AP_INPUT_RANGE_2,
E_AHI_ADC_SRC_VOLT);
}
/****************************************************************************
*
* NAME: vAppTick
*
* DESCRIPTION:
*
* Called by a BOS timer expiry. Reads sensor data and if complete transmits
* to coordinator.
*
****************************************************************************/
PRIVATE void vAppTick(void *pvMsg, uint8 u8Param)
{
uint8 u8Msg;
uint8 u8TimerId;
static bool_t bToggle;
/* Read sensor data */
vReadTempHumidity();
vReadBatteryVoltage();
if (u8AppTicks++ > APP_DATA_SEND_PERIOD)
{
/* If sensor reads are compete */
if ((sBattSensor.eState == E_STATE_READ_BATT_VOLTS_READY) &&
(sTempHumiditySensor.eState == E_STATE_READ_TEMP_HUMID_READY))
{
/* Toggle LED1 to show we are alive */
if (bToggle)
{
vLedControl(0,0);
}
else
{
vLedControl(0,1);
}
bToggle = !bToggle;
u8AppTicks = 0;
/* Transmit data to coordinator */
vSendData();
sBattSensor.eState = E_STATE_READ_BATT_VOLT_IDLE;
sTempHumiditySensor.eState = E_STATE_READ_TEMP_HUMID_IDLE;
}
}
(void)bBosCreateTimer(vAppTick, &u8Msg, 0, (APP_TICK_PERIOD_ms / 10), &u8TimerId);
}
/****************************************************************************
*
* NAME: vReadBatteryVoltage
*
* DESCRIPTION:
*
* Uses ADC to read supply voltage. Measurement is performed using a state
* machine to ensure that it never blocks.
*
****************************************************************************/
PRIVATE void vReadBatteryVoltage(void)
{
uint16 u16AdcReading;
switch(sBattSensor.eState)
{
case E_STATE_READ_BATT_VOLT_IDLE:
vAHI_AdcStartSample();
sBattSensor.eState = E_STATE_READ_BATT_VOLTS_ADC_CONVERTING;
break;
case E_STATE_READ_BATT_VOLTS_ADC_CONVERTING:
if (!bAHI_AdcPoll())
{
sBattSensor.eState = E_STATE_READ_BATT_VOLTS_COMPLETE;
}
break;
case E_STATE_READ_BATT_VOLTS_COMPLETE:
u16AdcReading = u16AHI_AdcRead();
/* Input range is 0 to 2.4V. ADC has full scale range of 12 bits.
Therefore a 1 bit change represents a voltage of approx 586uV */
sBattSensor.u16Reading = ((uint32)((uint32)(u16AdcReading * 586) +
((uint32)(u16AdcReading * 586) >> 1))) /
1000;
sBattSensor.eState = E_STATE_READ_BATT_VOLTS_READY;
break;
case E_STATE_READ_BATT_VOLTS_READY:
break;
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -