Skip to content
Snippets Groups Projects
ble.c 3.11 KiB
Newer Older
  • Learn to ignore specific revisions
  • #include "wsf_types.h"
    #include "wsf_os.h"
    #include "wsf_buf.h"
    #include "wsf_timer.h"
    #include "wsf_trace.h"
    #include "app_ui.h"
    #include "ll_api.h"
    #include "sch_api.h"
    #include "fit/fit_api.h"
    #include "mxc_config.h"
    #include "gcr_regs.h"
    #include "mcr_regs.h"
    #include "hci_core.h"
    
    #include <stdio.h>
    #include <string.h>
    
    /* Number of WSF buffer pools */
    #define WSF_BUF_POOLS              6
    
    /*! Free memory for pool buffers (use word elements for word alignment). */
    static uint32_t mainBufMem[3584/sizeof(uint32_t)+96];
    
    /*! Default pool descriptor. */
    static wsfBufPoolDesc_t mainPoolDesc[WSF_BUF_POOLS] =
    {
      {  16,  8 },
      {  32,  4 },
      {  64,  4 },
      { 128,  4 },
      { 256,  4 },
      { 384,  4 }
    };
    
    
    static void PlatformInit(void)
    {
        /* Change the pullup on the RST pin to 25K */
        /* TODO: Is this really needed? */
        MXC_MCR->ctrl = 0x202;
    
        /* Set VREGO_D to 1.3V */
        *((volatile uint32_t*)0x40004410) = 0x50;
    
        /* Set TX LDO to 1.1V and enable LDO. Set RX LDO to 0.9V and enable LDO */
        MXC_GCR->btleldocn = 0xD9; // TX 1.1V RX 0.9V
    
        /* Power up the 32MHz XO */
        MXC_GCR->clkcn |= MXC_F_GCR_CLKCN_X32M_EN;
    
        /* Enable peripheral clocks */
        /* TODO: Is this really needed? */
        MXC_GCR->perckcn0 &= ~(MXC_F_GCR_PERCKCN0_GPIO0D | MXC_F_GCR_PERCKCN0_GPIO1D);  // Clear GPIO0 and GPIO1 Disable
        MXC_GCR->perckcn1 &= ~(MXC_F_GCR_PERCKCN1_BTLED | MXC_F_GCR_PERCKCN1_TRNGD );  // Clear BTLE and ICACHE0 disable
    }
    
    static void myTrace(const char *pStr, va_list args)
    {
        extern uint8_t wsfCsNesting;
    
        if (wsfCsNesting == 0)
        {
            vprintf(pStr, args);
            printf("\r\n");
        }
    }
    
    static void WsfInit(void)
    {
        WsfTimerInit();
        WsfBufInit(sizeof(mainBufMem), (uint8_t*)mainBufMem, WSF_BUF_POOLS, mainPoolDesc);
        WsfTraceRegister(myTrace);
    }
    
    void MacInit(void)
    {
        wsfHandlerId_t handlerId;
    
        /* Initialize link layer. */
        BbInit();
        handlerId = WsfOsSetNextHandler(SchHandler);
        SchInit(handlerId);
        LlAdvSlaveInit();
        LlConnSlaveInit();
        handlerId = WsfOsSetNextHandler(LlHandler);
        LlHandlerInit(handlerId);
    }
    
    
    /* TODO: WTF? */
    /*
     * In two-chip solutions, setting the address must wait until the HCI interface is initialized.
     * This handler can also catch other Application events, but none are currently implemented.
     * See ble-profiles/sources/apps/app/common/app_ui.c for further details.
     *
     */
    void SetAddress(uint8_t event)
    {
        uint8_t bdAddr[6] = {0x02, 0x02, 0x44, 0x8B, 0x05, 0x00};
    
        switch (event) {
        case APP_UI_RESET_CMPL:
            printf("Setting address -- MAC %02X:%02X:%02X:%02X:%02X:%02X\n", bdAddr[5], bdAddr[4], bdAddr[3], bdAddr[2], bdAddr[1], bdAddr[0]);
            LlSetBdAddr((uint8_t*)&bdAddr);
            LlGetBdAddr(hciCoreCb.bdAddr);
            break;
        default:
            break;
        }
    }
    
    
    
    static void ble_init(void)
    {
        PlatformInit();
        WsfInit();
        MacInit();
        //StackInitFit();
        //FitStart();
    
        /* Register a handler for Application events */
        AppUiActionRegister(SetAddress);
    }
    
    
    void vBleTask(void*pvParameters)
    {
        ble_init();
        while (1){
            // TODO: this need some timing and sleeping
            wsfOsDispatcher();
        }
    }