CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

MRF89XA

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
in_nursery



Joined: 25 Oct 2012
Posts: 51

View user's profile Send private message

MRF89XA
PostPosted: Tue Feb 05, 2019 11:08 am     Reply with quote

Hi all
I make research on the forum with no luck. I'm stuck with a MRF89XA.

basic driver
MRF89XA.c
Code:

//////////////////////////////////////////////////////////////////////////
#include <MRF89XA.h>
//////////////////////////////////////////////////////////////////////////
// First time configuration settings for MRF89XA
//////////////////////////////////////////////////////////////////////////
unsigned int8 InitConfigRegs[] = {
      /* 0 */     CHIPMODE_STBYMODE | FREQBAND_915 | VCO_TRIM_11,
      /* 1 */     MODSEL_FSK | DATAMODE_PACKET | IFGAIN_0,
      /* 2 */     FREGDEV_80,
      /* 3 */     BITRATE_25,
      /* 4 */     OOKFLOORTHRESH_VALUE,
      /* 5 */     FIFOSIZE_64 | FIFO_THRSHOLD_1,
      /* 6 */     0,
      /* 7 */     0,
      /* 8 */     0,
      /* 9 */     0,
      /* 10 */    0,
      /* 11 */    0,
      /* 12 */    DEF_PARAMP | PA_RAMP_23,
      /* 13 */    IRQ0_RX_STDBY_SYNCADRS | IRQ1_RX_STDBY_CRCOK | IRQ1_TX_TXDONE,                     
      /* 14 */    DEF_IRQPARAM1 | IRQ0_TX_START_FIFOTHRESH | IRQ1_PLL_LOCK_PIN_ON,
      /* 15 */    RSSIIRQTHRESH_VALUE,
      /* 16 */    PASSIVEFILT_378 | RXFC_FOPLUS100,
      /* 17 */    DEF_RXPARAM1 | FO_100,
      /* 18 */    DEF_RXPARAM2 | POLYPFILT_OFF | SYNC_SIZE_32 | SYNC_ON | SYNC_ERRORS_0,
      /* 19 */    DEF_RXPARAM3,
      /* 20 */    0,
      /* 21 */    OOK_THRESH_DECSTEP_000 | OOK_THRESH_DECPERIOD_000 | OOK_THRESH_AVERAGING_00,
      /* 22 */    0x69, // 1st byte of Sync word,
      /* 23 */    0x81, // 2nd byte of Sync word,
      /* 24 */    0x7E, // 3rd byte of Sync word,
      /* 25 */    0x96, // 4th byte of Sync word,
      /* 26 */    FC_400 | TXPOWER_13,
      /* 27 */    CLKOUT_ON | CLKOUT_12800,
      /* 28 */    MANCHESTER_OFF | 64,
      /* 29 */    NODEADRS_VALUE,
      /* 30 */    PKT_FORMAT_VARIABLE | PREAMBLE_SIZE_4 | WHITENING_OFF | CRC_ON | ADRSFILT_NONE,
      /* 31 */    FIFO_AUTOCLR_ON | FIFO_STBY_ACCESS_WRITE
                  };   
//////////////////////////////////////////////////////////////////////////
// Register Set
//////////////////////////////////////////////////////////////////////////
void RegisterSet(int8 address, int8 value)
{
   output_low(CSCON);
   
   address = (address<<1);
   spi_write (address);
   spi_write (value);
   
   output_high(CSCON); 
}
//////////////////////////////////////////////////////////////////////////
// Register Read
//////////////////////////////////////////////////////////////////////////
int8 RegisterRead(int8 address)
{
   unsigned int8 data_r = 0, dummy_data_r = 0;
   
   output_low(CSCON);
   
   delay_ms(50);
   address = ((address<<1)|0x40);
   spi_write(dummy_data_r);
   data_r = spi_read(dummy_data_r);
   
   output_high(CSCON);
   return data_r;
}
//////////////////////////////////////////////////////////////////////////
// SetRFMode(int8 mode)
// Sets the MRF89XA transceiver operating mode to:
// sleep, transmit, receive or standby
//////////////////////////////////////////////////////////////////////////     
void SetRFMode(int8 mode)
{
   int8   mcparam0_read;
   mcparam0_read = RegisterRead(REG_MCPARAM0);
   switch (mode) {
      case RF_TRANSMITTER:
         RegisterSet(REG_MCPARAM0, (mcparam0_read & 0x1F) | RF_TRANSMITTER);
         RF_Mode = RF_TRANSMITTER;            //RF in TX mode
         break;
      case RF_RECEIVER:
         RegisterSet(REG_MCPARAM0, (mcparam0_read & 0x1F) | RF_RECEIVER);
         RF_Mode = RF_RECEIVER;               //RF in RX mode
         break;
      case RF_SYNTHESIZER:
         RegisterSet(REG_MCPARAM0, (mcparam0_read & 0x1F) | RF_SYNTHESIZER);
         RF_Mode = RF_SYNTHESIZER;            //RF in Synthesizer mode
         break;
      case RF_STANDBY:
         RegisterSet(REG_MCPARAM0, (mcparam0_read & 0x1F) | RF_STANDBY);
         RF_Mode = RF_STANDBY;               //RF in standby mode
         break;
      case RF_SLEEP:
         RegisterSet(REG_MCPARAM0, (mcparam0_read & 0x1F) | RF_SLEEP);
         RF_Mode = RF_SLEEP;                  //RF in sleep mode
         break;   
   }
}
//////////////////////////////////////////////////////////////////////////
// WriteFIFO(BYTE Data)
// Fills the FIFO
//////////////////////////////////////////////////////////////////////////
void WriteFIFO(int8 Data)
{
    output_low(CSDATA);
   
    spi_write(Data);
   
    output_high(CSDATA);
}

//////////////////////////////////////////////////////////////////////////
//  ReadFIFO(void)
//  Reads the Reiceved frame from the fifo and sets hasPacket accordingly
//////////////////////////////////////////////////////////////////////////
unsigned int8 ReadFIFO(void)
{   
    unsigned int8 data_r = 0, dummy_data_r = 0;
   
    output_low(CSDATA);
   
    data_r = spi_read(dummy_data_r);
   
    output_high(CSDATA);
    return data_r;
}
//////////////////////////////////////////////////////////////////////////
//  MRF89XAInit(void)
//  This function reads the Reiceved frame from the fifo and sets hasPacket accordingly
//////////////////////////////////////////////////////////////////////////
void MRF89XAInit(void)
{
   int8 input,i=0;
   for (i = 0 ; i <= 31; i++)
   {
      RegisterSet(i, InitConfigRegs[i]);
   }
   RF_Mode = RF_STANDBY;
   input = RegisterRead(REG_MCPARAM0);
   RegisterSet(REG_MCPARAM0, (input & 0x1F) | RF_SYNTHESIZER);             
   RF_Mode = RF_SYNTHESIZER;
   /* clear PLL_LOCK flag so we can see it restore on the new frequency */\
   input = RegisterRead(REG_IRQPARAM1);
   RegisterSet(REG_IRQPARAM1, (input | 0x02));
   input = RegisterRead(REG_MCPARAM0);
   RegisterSet(REG_MCPARAM0, ((input & 0xE7) | FREQBAND_915));
   //Program R, P,S registers
   RegisterSet(REG_R1, 119);
   RegisterSet(REG_P1, 100);
   RegisterSet(REG_S1, 52);
   input = RegisterRead(REG_MCPARAM0);
   RegisterSet(REG_MCPARAM0, ((input & 0x1F) | RF_SYNTHESIZER));             
   RF_Mode = RF_SYNTHESIZER;
   /* clear PLL_LOCK flag so we can see it restore on the new frequency */
   input = RegisterRead(REG_IRQPARAM1);
   RegisterSet(REG_IRQPARAM1, (input | 0x02));
   SetRFMode(RF_STANDBY);
   //PHY_IRQ1_En = 1;
   
}
//////////////////////////////////////////////////////////////////////////
// Send_Packet(int8 TxPacketLen)
// Send the packet in the buffer TxPacket
//////////////////////////////////////////////////////////////////////////
void Send_Packet(int8 TxPacketLen)
{
   int8 i;
   int8 j;
   SetRFMode(RF_STANDBY);
   RegisterSet(REG_PKTPARAM3, ((InitConfigRegs[REG_PKTPARAM3] & 0xBF)| FIFO_STBY_ACCESS_WRITE));
   RegisterSet(REG_IRQPARAM0, (InitConfigRegs[REG_IRQPARAM0] | IRQ1_FIFO_OVERRUN_CLEAR ));
   RegisterSet(REG_IRQPARAM1, ((InitConfigRegs[REG_IRQPARAM1]) | 0x02));
   WriteFIFO(TxPacketLen+1);
   WriteFIFO(0x05);      //Node_adrs
   for(i=0; i< TxPacketLen; i++)
   {
      WriteFIFO(TxPacket[i]);
   }
   SetRFMode(RF_TRANSMITTER);
   delay_ms(100);
   SetRFMode(RF_STANDBY);   
   //Reset FIFO
   j = RegisterRead(REG_IRQPARAM0);
   RegisterSet(REG_IRQPARAM0, (j | 0x01));
}

//////////////////////////////////////////////////////////////////////////
// ReceiveFrame(void)
// Reads the Reiceved frame from the fifo and sets hasPacket accordingly
//////////////////////////////////////////////////////////////////////////
void ReceiveFrame(void)
{
   int8 data, node_adrs;
   int8 i = 0;
   int8 j = 0;
  // if(IRQ1_Received)
  //    {
      RxPacketLen = ReadFIFO();
         DRxPacketLen =RxPacketLen;
      node_adrs = ReadFIFO();
         Dnode_adrs =node_adrs;
      RxPacketLen = (RxPacketLen-1);

      while(RxPacketLen--)
         {
         data = ReadFIFO();
         RxPacket[i] = data;
         i++;
         };
      RxPacketLen = i;
      //}   
 //  IRQ1_Received = FALSE;
   hasPacket = TRUE;
   //Reset FIFO
   j = RegisterRead(REG_IRQPARAM0);
   RegisterSet(REG_IRQPARAM0, (j | 0x01));
}


MRF89XA.h
Code:

/*********************************************************************
 *                  MRF89XA Radio specific defs.
 *********************************************************************
 * Company:         Microchip Technology, Inc.
 *
 * Software License Agreement
 *
 * The software supplied herewith by Microchip Technology Incorporated
 * (the “Company”) for its PICmicro® Microcontroller is intended and
 * supplied to you, the Company’s customer, for use solely and
 * exclusively on Microchip PICmicro Microcontroller products. The
 * software is owned by the Company and/or its supplier, and is
 * protected under applicable copyright laws. All rights are reserved.
 * Any use in violation of the foregoing restrictions may subject the
 * user to criminal sanctions under applicable laws, as well as to
 * civil liability for the breach of the terms and conditions of this
 * license.
 *
 * THIS SOFTWARE IS PROVIDED IN AN “AS IS” CONDITION. NO WARRANTIES,
 * WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT NOT LIMITED
 * TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
 * PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. THE COMPANY SHALL NOT,
 * IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL OR
 * CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
 ********************************************************************/
#ifndef _MRF89XA_
#define _MRF89XA_
/********************************************************************
MRF89XA Operating modes
**********************************************************************/
#define RF_SLEEP                         0x00
#define RF_STANDBY                       0x20
#define RF_SYNTHESIZER                   0x40
#define RF_RECEIVER                      0x60
#define RF_TRANSMITTER                   0x80

/*********************************************************************
MRF89XA Register Description
*********************************************************************/

#define REG_MCPARAM0                     0
   #define CHIPMODE_SLEEPMODE  0x00   //000 [7:5]
   #define CHIPMODE_STBYMODE    0x20   //001 ;default
   #define CHIPMODE_FSMODE       0x40   //010
   #define CHIPMODE_RX          0x60   //011
   #define CHIPMODE_TX          0x80   //100

   #define FREQBAND_902      0x00   //902-915 00 [4:3]
   #define FREQBAND_915      0x08   //915-928 01 ;default
   #define FREQBAND_950      0x10   //950-960 or 863-870 10
   
   #define VCO_TRIM_00         0x00   // [2:1] Vtune determined by tank inductor values
   #define VCO_TRIM_01         0x02
   #define VCO_TRIM_10         0x04
   #define VCO_TRIM_11         0x06

#define REG_MCPARAM1                     1
   #define MODSEL_OOK         0x40   //01 [7:6]
   #define MODSEL_FSK         0x80   //10 ;default

   #define OOKTHRESHTYPE_FIXED 0x00   //00 [4:3]
   #define OOKTHRESHTYPE_PEAK   0x08   //01
   #define OOKTHRESHTYPE_AVG   0x10   //10

   #define DATAMODE_CONTINUOUS 0x00   //00 [Bit2,Bit5];default
   #define DATAMODE_BUFFERED   0x20   //01
   #define DATAMODE_PACKET       0x04   //1x
   
   #define IFGAIN_0         0x00   //00 [1:0] 0dB ;default
   #define IFGAIN_45         0x01   //01 -4.5dB
    #define IFGAIN_9         0x02   //10 -9dB
   #define IFGAIN_135         0x03   //11 -13.5dB

#define REG_FREGDEV                      2      //default D = 00000011, FDEV = 133 kHz
      //values may change - should be calculated based on crystal frequency - 12.8 MHz (fxtal/32/(D+1))
      #define FREGDEV_33      0x0B
      #define FREGDEV_40      0x09
      #define FREGDEV_50      0x07
      #define FREGDEV_67      0x05
      #define FREGDEV_80      0x04
      #define FREGDEV_100      0x03
      #define FREGDEV_133      0x02
      #define FREGDEV_200      0x01
   
#define REG_BITRATE                      3
                                    //default C = 0000111, BR = 25 Kbps
      #define BITRATE_200      0x00
      #define BITRATE_100      0x01
      #define BITRATE_66      0x02
      #define BITRATE_50      0x03
      #define BITRATE_40      0x04
      #define BITRATE_25      0x07
      #define BITRATE_20      0x09
      #define BITRATE_16      0x0B
      #define BITRATE_10      0x13
      #define BITRATE_5      0x27
      #define BITRATE_2      0x63
      #define BITRATE_1_56   0x7F
      #define BITRATE_2_41   0x52
      #define BITRATE_4_76   0x29
      #define BITRATE_8      0x18
      #define BITRATE_9_52   0x14
      #define BITRATE_12_5   0x0F
      #define BITRATE_16_67   0x0B

#define REG_OOKFLOORTHRESH               4
   // OOK threshold (reg4)
   #define OOKFLOORTHRESH_VALUE 0x0C

   
#define REG_MCPARAM5                     5
   #define FIFOSIZE_16         0x00   //00 [7:6] - 16bytes - default
   #define FIFOSIZE_32         0x40
   #define FIFOSIZE_48         0x80
   #define FIFOSIZE_64         0xC0
   
   #define FIFO_THRSHOLD_31   0x0F   //31 bytes - default [5:0]
   #define FIFO_THRSHOLD_1    0x01

#define REG_R1                           6

#define REG_P1                           7

#define REG_S1                           8

#define REG_R2                           9

#define REG_P2                           10

#define REG_S2                           11

#define REG_MCPARAM12                    12
   #define PA_RAMP_3         0x00   //[4:3] - 3us
   #define PA_RAMP_85         0x08   //8.5us
   #define PA_RAMP_15         0x10   //15us
   #define PA_RAMP_23         0x18   //23us
   #define DEF_PARAMP         0x20
#define REG_IRQPARAM0                    13
   // IRQ Param 0 (reg13)
   // Select RX&STDBY IRQ_0 sources (Packet mode) (reg13)
   #define IRQ0_RX_STDBY_PAYLOADREADY    0x00
   #define IRQ0_RX_STDBY_WRITEBYTE       0x40
   #define IRQ0_RX_STDBY_FIFOEMPTY       0x80
   #define IRQ0_RX_STDBY_SYNCADRS        0xC0
   
   // Select RX&STDBY IRQ_1 sources (Packet mode) (reg13)
   #define IRQ1_RX_STDBY_CRCOK           0x00
   #define IRQ1_RX_STDBY_FIFOFULL        0x10
   #define IRQ1_RX_STDBY_RSSI            0x20
   #define IRQ1_RX_STDBY_FIFOTHRESH      0x30
   
   // Select TX IRQ_1 sources (Packet mode) (reg13)
   #define IRQ1_TX_FIFOFULL              0x00
   #define IRQ1_TX_TXDONE                0x08

   // Select TX IRQ_1 sources (Continuous mode) (reg13)
   #define IRQ1_TX_DCLK                   0x00

   
   // FIFO overrun/clear  (reg13)
   #define IRQ1_FIFO_OVERRUN_CLEAR       0x01
   

#define REG_IRQPARAM1                    14
   // IRQ Param 1
   #define DEF_IRQPARAM1              0x08
   // Select TX start condition and IRQ_0 source (Packet mode)
   #define IRQ0_TX_START_FIFOTHRESH      0x00
   #define IRQ0_TX_START_FIFONOTEMPTY    0x10
   
   // RSSI IRQ flag
   #define IRQ1_RSSI_IRQ_CLEAR           0x04
   
   // PLL_Locked flag
   #define IRQ1_PLL_LOCK_CLEAR           0x02
   
   // PLL_Locked pin
   #define IRQ1_PLL_LOCK_PIN_OFF         0x00
   #define IRQ1_PLL_LOCK_PIN_ON          0x01
   
   // RSSI threshold for interrupt
   #define RSSIIRQTHRESH_VALUE           0x00

#define NODEADRS_VALUE          0x00


#define REG_RSSIIRQTHRESH                15

#define REG_RXPARAM0                     16
   // RX Param 0
   // Passive filter (kHz)
   #define PASSIVEFILT_65            0x00      //65 KHz
   #define PASSIVEFILT_82            0x10      //82 KHz
   #define PASSIVEFILT_109           0x20
   #define PASSIVEFILT_137           0x30
   #define PASSIVEFILT_157           0x40
   #define PASSIVEFILT_184           0x50
   #define PASSIVEFILT_211           0x60
   #define PASSIVEFILT_234           0x70
   #define PASSIVEFILT_262           0x80
   #define PASSIVEFILT_321           0x90
   #define PASSIVEFILT_378           0xA0
   #define PASSIVEFILT_414           0xB0
   #define PASSIVEFILT_458           0xC0
   #define PASSIVEFILT_514           0xD0
   #define PASSIVEFILT_676           0xE0
   #define PASSIVEFILT_987           0xF0
   
   // Butterworth filter (kHz)
   #define RXFC_VALUE                  0x03
   // !!! Values defined below only apply if XTAL frequency == 12.8MHz !!!
   #define RXFC_FOPLUS25               0x00
   #define RXFC_FOPLUS50               0x01
   #define RXFC_FOPLUS75               0x02
   #define RXFC_FOPLUS100              0x03
   #define RXFC_FOPLUS125              0x04
   #define RXFC_FOPLUS150              0x05
   #define RXFC_FOPLUS175              0x06
   #define RXFC_FOPLUS200              0x07
   #define RXFC_FOPLUS225              0x08
   #define RXFC_FOPLUS250              0x09
   #define RXFC_FOPLUS275            0x0A
   #define RXFC_FOPLUS300            0x0B
   #define RXFC_FOPLUS325            0x0C
   #define RXFC_FOPLUS350            0x0D
   #define RXFC_FOPLUS375            0x0E
   #define RXFC_FOPLUS400            0x0F




#define REG_RXPARAM1                     17
   // RX Param 1
   #define DEF_RXPARAM1           0x08
   // Polyphase filter center value (kHz)
   #define FO_VALUE                  0x30

   // !!! Values defined below only apply if RFCLKREF = DEFAULT VALUE = 0x07 !!!
   #define FO_50                     0x10
   #define FO_75                     0x20
   #define FO_100                    0x30
   #define FO_125                    0x40
   #define FO_150                    0x50
   #define FO_175                    0x60
   #define FO_200                    0x70
   #define FO_225                    0x80
   #define FO_250                    0x90
   #define FO_275                    0xA0
   #define FO_300                    0xB0
   #define FO_325                    0xC0
   #define FO_350                    0xD0
   #define FO_375                    0xE0
   #define FO_400                    0xF0


#define REG_RXPARAM2                     18
   // Rx Param 2
   // Polyphase filter enable
   #define POLYPFILT_ON              0x80
   #define POLYPFILT_OFF             0x00

   #define DEF_RXPARAM2            0x20
   #define SYNC_ON                  0x20   //[5] - 0 - off, 1 - on
   #define SYNC_SIZE_8               0x00   //[4:3] - 00 - 8 bits
   #define SYNC_SIZE_16            0x08
   #define SYNC_SIZE_24            0x10
   #define SYNC_SIZE_32            0x18
   #define SYNC_ERRORS_0            0x00   //[2:1] - 00 - 0 error
   #define SYNC_ERRORS_1            0x02
   #define SYNC_ERRORS_2            0x04
   #define SYNC_ERROS_3            0x06
#define REG_RXPARAM3                     19            //Reserved
   #define DEF_RXPARAM3            0x07
#define REG_RSSIVALUE                    20
   //RSSI value (READ ONLY)
#define REG_OOKSETTINGS                  21
   // Rx Param 5
   // Decrement step of RSSI threshold in OOK demodulator (peak mode)
   #define OOK_THRESH_DECSTEP_000    0x00
   #define OOK_THRESH_DECSTEP_001    0x20
   #define OOK_THRESH_DECSTEP_010    0x40
   #define OOK_THRESH_DECSTEP_011    0x60
   #define OOK_THRESH_DECSTEP_100    0x80
   #define OOK_THRESH_DECSTEP_101    0xA0
   #define OOK_THRESH_DECSTEP_110    0xC0
   #define OOK_THRESH_DECSTEP_111    0xE0
   
   // Decrement period of RSSI threshold in OOK demodulator (peak mode)
   #define OOK_THRESH_DECPERIOD_000  0x00
   #define OOK_THRESH_DECPERIOD_001  0x04
   #define OOK_THRESH_DECPERIOD_010  0x08
   #define OOK_THRESH_DECPERIOD_011  0x0C
   #define OOK_THRESH_DECPERIOD_100  0x10
   #define OOK_THRESH_DECPERIOD_101  0x14
   #define OOK_THRESH_DECPERIOD_110  0x18
   #define OOK_THRESH_DECPERIOD_111  0x1C
   
   // Cutoff freq of average function of RSSI threshold in OOK demodulator (average mode)
   #define OOK_THRESH_AVERAGING_00   0x00
   #define OOK_THRESH_AVERAGING_11   0x03

#define REG_SYNCBYTE0                    22
#define REG_SYNCBYTE1                    23
#define REG_SYNCBYTE2                    24
#define REG_SYNCBYTE3                    25

#define REG_TXPARAM                      26
   // TX Param
   // Interpolator filter Tx (kHz)
   #define FC_VALUE                   0x70
   // !!! Values defined below only apply if RFCLKREF = DEFAULT VALUE = 0x07 !!!
   #define FC_25                      0x00
   #define FC_50                      0x10
   #define FC_75                      0x20
   #define FC_100                     0x30
   #define FC_125                     0x40
   #define FC_150                     0x50
   #define FC_175                     0x60
   #define FC_200                     0x70
   #define FC_225                     0x80
   #define FC_250                     0x90
   #define FC_275                     0xA0
   #define FC_300                     0xB0
   #define FC_325                     0xC0
   #define FC_350                     0xD0
   #define FC_375                     0xE0
   #define FC_400                     0xF0

   #define TXPOWER_13               0x00   //[3:1] - 13dB
   #define TXPOWER_10               0x02   
   #define TXPOWER_7                  0x04
   #define TXPOWER_4                  0x06
   #define TXPOWER_1                  0x08
   #define TXPOWER_2                  0x0A
   #define TXPOWER_5                  0x0C
   #define TXPOWER_8                  0x0E

#define REG_OSCPARAM                     27
   // OSC Param
   // CLKOUT enable
   #define CLKOUT_ON                 0x80
   #define CLKOUT_OFF                0x00
   
   // CLKOUT frequency (kHz)
   #define CLKOUT_12800              0x00
   #define CLKOUTint64_t00           0x04
   #define CLKOUT_3200               0x08
   #define CLKOUT_2133               0x0C
   #define CLKOUT_1600               0x10
   #define CLKOUT_1280               0x14
   #define CLKOUT_1067               0x18
   #define CLKOUT_914                0x1C
   #define CLKOUT_800                0x20
   #define CLKOUT_711                0x24
   #define CLKOUT_64                0x28
   #define CLKOUT_582                0x2C
   #define CLKOUT_533                0x30
   #define CLKOUT_492                0x34
   #define CLKOUT_457                0x38
   #define CLKOUT_427                0x3C


#define REG_PKTPARAM0                    28
   #define MANCHESTER_ON            0x80   //[7] 0 - off, 1 - on
   #define MANCHESTER_OFF            0x00
#define REG_NODEADDRESS                  29
#define REG_PKTPARAM2                    30
   #define PKT_FORMAT_FIXED         0x00   //[7] 0 - fixed length, 1- variable length
   #define PKT_FORMAT_VARIABLE         0x80
   #define PREAMBLE_SIZE_1            0x00    //[6:5] 00 - 1 byte
   #define PREAMBLE_SIZE_2            0x20
   #define PREAMBLE_SIZE_3            0x40
   #define PREAMBLE_SIZE_4            0x60
   
   #define WHITENING_ON            0x10   //[4] 0 - off, 1 - On
   #define WHITENING_OFF            0x00   
   
   #define CRC_ON                  0x08   //[3] 0 - off, 1 - On
   #define CRC_OFF                  0x00   
   // Address filtering
   #define ADRSFILT_NONE            0x00   /* no filtering */
   #define ADRSFILT_ME_ONLY         0x02   /* only Node_adrs accepted (register 29) */
   #define ADRSFILT_ME_AND_00         0x04   /* Node_adrs and 0x00 accepted */
   #define ADRSFILT_ME_AND_00_AND_FF   0x06   /* Node_adrs and 0x00 and 0xff accepted */


#define REG_PKTPARAM3                    31
   #define FIFO_AUTOCLR_ON            0x00   //[7] 0 - On, 1 - Off
   #define FIFO_AUTOCLR_OFF         0x80

   #define FIFO_STBY_ACCESS_WRITE      0x00   //[6] 0 - Write, 1 - Read
   #define FIFO_STBY_ACCESS_READ      0x40

#endif


TX.C
Code:

//////////////////////////////////////////////////////////////////////////
#include <18f46k20.h>
//////////////////////////////////////////////////////////////////////////
#fuses   INTRC       // Internal RC Osc
#fuses   NODEBUG    // No Debug mode for ICD
#fuses   NOWRT       // Program memory not write protected
#fuses   NOCPD       // No EE protection
#fuses   NOLVP       // No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#fuses   NOPUT       // No Power Up Timer
#fuses   NOBROWNOUT    // Reset when brownout detected
#fuses   BORV30       // Brownout reset at 3.0V
#fuses   NOWDT       // No Watch Dog Timer
#fuses   MCLR        // Master Clear pin enabled
//////////////////////////////////////////////////////////////////////////
//        Clock
//////////////////////////////////////////////////////////////////////////
#use delay(internal=4000000, restart_wdt) // inclure procédure de délais (delay_ms() et delay_us())
//////////////////////////////////////////////////////////////////////////
//        Define
// CSCON    => D2
// CSDATA   => D0
// SDI      => C5
// SDO      => C4
// SCK      => C3
// IRQ0     => NC
// IRQ1     => NC
// RESET    => D1
//////////////////////////////////////////////////////////////////////////
#define PACKET_LEN 64
#define CSDATA    PIN_D0  // Serial Interface CS data
#define CSCON     PIN_D2  // Serial Interface CS Conf
#define RESET     PIN_D1   // Reset
//////////////////////////////////////////////////////////////////////////
//        Global
//////////////////////////////////////////////////////////////////////////
int8 RF_Mode;
int8 TxPacket[PACKET_LEN];
int8 RxPacketLen=0;
int8 RxPacket[PACKET_LEN];
int1 hasPacket = FALSE;
//////////////////////////////////////////////////////////////////////////
//        Debug
//////////////////////////////////////////////////////////////////////////
int8 Dnode_adrs;
int8 DRxPacketLen;
//////////////////////////////////////////////////////////////////////////
//        Include
//////////////////////////////////////////////////////////////////////////
#include <MRF89XA.c>
//////////////////////////////////////////////////////////////////////////
//        Main
//////////////////////////////////////////////////////////////////////////
void main()
{
output_high(CSCON);
output_high(CSDATA);
output_high(PIN_C6); // pin Power ON
output_high(PIN_B2); // Led Green
output_high(RESET);  // reset pin
delay_ms(100);
//Setup OSC
setup_oscillator(OSC_4MHZ|OSC_INTRC);
//Setup SPI
setup_spi(SPI_MASTER | SPI_L_TO_H | SPI_XMIT_L_TO_H );
//Init radio
MRF89XAInit();
//TX
TxPacket[0] = 1;
TxPacket[1] = 2;
TxPacket[2] = 3;
TxPacket[3] = 4;
// RX
RxPacket[0] = 0;
while(1)
  {
   //send
   output_high(PIN_B5); //led blue
   Send_Packet(64); 
   output_low(PIN_B5); // led blue
   delay_ms(500);
  }
}


RX.C
Code:

//////////////////////////////////////////////////////////////////////////
#include <18f46k20.h>
 
//////////////////////////////////////////////////////////////////////////
#fuses   INTRC       // Internal RC Osc
#fuses   NODEBUG    // No Debug mode for ICD
#fuses   NOWRT       // Program memory not write protected
#fuses   NOCPD       // No EE protection
#fuses   NOLVP       // No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#fuses   NOPUT       // No Power Up Timer
#fuses   NOBROWNOUT    // Reset when brownout detected
#fuses   BORV30       // Brownout reset at 3.0V
#fuses   NOWDT       // No Watch Dog Timer
#fuses   MCLR        // Master Clear pin enabled
//////////////////////////////////////////////////////////////////////////
//        Clock
//////////////////////////////////////////////////////////////////////////
#use delay(internal=4000000, restart_wdt) // inclure procédure de délais (delay_ms() et delay_us())
//////////////////////////////////////////////////////////////////////////
//        Define
// CSCON    => D2
// CSDATA   => D0
// SDI      => C5
// SDO      => C4
// SCK      => C3
// IRQ0     => NC
// IRQ1     => NC
// RESET    => D1
//////////////////////////////////////////////////////////////////////////
#define PACKET_LEN 64
#define CSDATA    PIN_D0  // Serial Interface CS data
#define CSCON     PIN_D2  // Serial Interface CS Conf
#define RESET     PIN_D1   // Reset
//////////////////////////////////////////////////////////////////////////
//        Global
//////////////////////////////////////////////////////////////////////////
int8 RF_Mode;
int8 TxPacket[PACKET_LEN];
int8 RxPacketLen=0;
int8 RxPacket[PACKET_LEN];
int1 hasPacket = FALSE;
//////////////////////////////////////////////////////////////////////////
//        Debug
//////////////////////////////////////////////////////////////////////////
int8 Dnode_adrs;
int8 DRxPacketLen;
//////////////////////////////////////////////////////////////////////////
//        Include
//////////////////////////////////////////////////////////////////////////
#include <MRF89XA.c>
//////////////////////////////////////////////////////////////////////////
//        Main
//////////////////////////////////////////////////////////////////////////
void main()
{
delay_ms(2000);
output_high(CSCON);
output_high(CSDATA);
output_high(PIN_C6); // pin Power ON
output_high(PIN_B2); // Led Green
output_high(RESET);  // reset pin
delay_ms(100);
//Setup OSC
setup_oscillator(OSC_4MHZ|OSC_INTRC);
//Setup SPI
setup_spi(SPI_MASTER | SPI_L_TO_H | SPI_XMIT_L_TO_H );
//Init radio
MRF89XAInit();
//TX
TxPacket[0] = 1;
TxPacket[1] = 2;
TxPacket[2] = 3;
TxPacket[3] = 4;
// RX
RxPacket[0] = 0;
while(1)
   {
   SetRFMode(RF_RECEIVER);
   ReceiveFrame();
   if (RXpacket[0]==1)
      {
      output_high(PIN_B5); // led Blue
      delay_ms(500);
      }
   else
      {
      output_low(PIN_B5);  // led Blue
      delay_ms(500);
      }
   }
}


Fifo in RX is always empty, I don't use IRQ0 and IRQ1 for the moment.
temtronic



Joined: 01 Jul 2010
Posts: 9241
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Feb 05, 2019 11:47 am     Reply with quote

Without looking at all the code...a couple of 'low level' questions...
1) do you have the correct power for the devices ? Most 'peripherals' are 3 volts these days...have you enough current to power it as well ?

2) can you actually set and read various registers of the device for both xmtr and rcvr units ??

Jay
in_nursery



Joined: 25 Oct 2012
Posts: 51

View user's profile Send private message

PostPosted: Tue Feb 05, 2019 2:45 pm     Reply with quote

So voltage is 3.3V

after some small issue I check that I can read and write configuration on each.

but still no RX.

I change:
#fuses INTRC_IO
and
output_low(RESET); // reset pin
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group