From bc6e2b0d07341884c63511995335e84b6c218bed Mon Sep 17 00:00:00 2001
From: schneider <schneider@blinkenlichts.net>
Date: Sun, 5 May 2019 23:37:53 +0200
Subject: [PATCH] feat(helloworld): Setup pmic

---
 Hello_World/Makefile |  5 ++-
 Hello_World/main.c   | 82 ++++++++++++++++++++++++++++++++++++++++++--
 2 files changed, 84 insertions(+), 3 deletions(-)

diff --git a/Hello_World/Makefile b/Hello_World/Makefile
index 7ed25360..e8bcc558 100644
--- a/Hello_World/Makefile
+++ b/Hello_World/Makefile
@@ -69,7 +69,7 @@ SRCS  = main.c
 SRCS  += ../lib/card10/oled96.c
 SRCS  += ../lib/card10/fonts.c
 SRCS  += bhy_support.c bhy_uc_driver.c bhy.c
-
+SRCS  += MAX77650-Arduino-Library.c
 # Where to find source files for this test
 VPATH = .
 
@@ -83,6 +83,9 @@ IPATH += ../lib/bosch/BHy1_driver_and_MCU_solution/driver/inc
 IPATH += ../lib/bosch/BHy1_driver_and_MCU_solution/examples/firmware/
 VPATH += ../lib/bosch/BHy1_driver_and_MCU_solution/driver/src
 
+IPATH += ../lib/maxim/MAX77650-Arduino-Library
+VPATH += ../lib/maxim/MAX77650-Arduino-Library
+
 # Enable assertion checking for development
 PROJ_CFLAGS+=-DMXC_ASSERT_ENABLE
 
diff --git a/Hello_World/main.c b/Hello_World/main.c
index e691950e..b2ff8b22 100644
--- a/Hello_World/main.c
+++ b/Hello_World/main.c
@@ -55,6 +55,7 @@
 #include "bhy.h"
 #include "Bosch_PCB_7183_di03_BMI160_BMM150-7183_di03.2.1.11696_170103.h"
 #include "bhy_uc_driver.h"
+#include "MAX77650-Arduino-Library.h"
 
 /***** Definitions *****/
 
@@ -95,6 +96,70 @@ uint32_t ecg_read_reg(uint8_t reg)
     return (rx_data[1] << 16) | (rx_data[2] << 8) | rx_data[3];
 }
 
+void pmic_init(void)
+{
+
+    uint8_t didm = MAX77650_getDIDM();
+    uint8_t cid = MAX77650_getChipID();
+    printf("MAX7765x DIDM: 0x%02x CID: 0x%02x\n", didm, cid);
+
+    MAX77650_setIP_SBB0(0b11);  //Limit output of SBB0 to 500mA
+    MAX77650_setTV_SBB0(0b101000); //Set output Voltage of SBB0 to 1.8V
+    MAX77650_setADE_SBB0(0b0); //Disable Active Discharge at SBB0 Output
+    MAX77650_setEN_SBB0(0b110); //Enable SBB0 is on irrespective of FPS whenever the on/off controller is in its "On via Software" or "On via On/Off Controller" states
+
+    MAX77650_setIP_SBB1(0b11);  //Limit output of SBB1 to 500mA
+    MAX77650_setTV_SBB1(0b100000); //Set output Voltage of SBB1 to 1.2V
+    //MAX77650_setTV_SBB1(0b100010); //Set output Voltage of SBB1 to 3.3V
+    MAX77650_setADE_SBB1(0b0); //Disable Active Discharge at SBB1 Output
+    MAX77650_setEN_SBB1(0b110); //Enable SBB1 is on irrespective of FPS whenever the on/off controller is in its "On via Software" or "On via On/Off Controller" states
+
+    MAX77650_setIP_SBB2(0b11);  //Limit output of SBB2 to 500mA
+    MAX77650_setTV_SBB2(0b110010); //Set output Voltage of SBB2 to 3.3V
+    //MAX77650_setTV_SBB2(0b110100); //Set output Voltage of SBB2 to 5.0V
+    MAX77650_setADE_SBB2(0b0); //Disable Active Discharge at SBB2 Output
+    MAX77650_setEN_SBB2(0b110); //Enable SBB2 is on irrespective of FPS whenever the on/off controller is in its "On via Software" or "On via On/Off Controller" states
+
+
+    // Prepare the PMIC LEDs
+    MAX77650_setLED_FS0(0b01);
+    MAX77650_setINV_LED0(false);    //LED red: phase operation
+    MAX77650_setBRT_LED0(0b00000);  //LED red: brightness
+    MAX77650_setP_LED0(0b1111);     //LED red: LED period
+    MAX77650_setD_LED0(0b1111);     //LED red: LED duty-cycle
+
+    MAX77650_setLED_FS1(0b01);
+    MAX77650_setINV_LED1(false);    //LED green: phase operation
+    MAX77650_setBRT_LED1(0b00000);  //LED green: brightness
+    MAX77650_setP_LED1(0b1111);     //LED green: LED period
+    MAX77650_setD_LED1(0b1111);     //LED green: LED duty-cycle
+
+    MAX77650_setLED_FS2(0b01);
+    MAX77650_setINV_LED2(false);    //LED blue: phase operation
+    MAX77650_setBRT_LED2(0b00000);  //LED blue: brightness
+    MAX77650_setP_LED2(0b1111);     //LED blue: LED period
+    MAX77650_setD_LED2(0b1111);     //LED blue: LED duty-cycle
+
+    MAX77650_setEN_LED_MSTR(true);  //LEDs Master enable
+}
+
+void set_led(uint8_t led, uint8_t val)
+{
+    if(led == 0) {
+        MAX77650_setLED_FS0(val > 0 ? 0b01 : 0);
+        MAX77650_setBRT_LED0(val);
+    }
+    if(led == 1) {
+        MAX77650_setLED_FS1(val > 0 ? 0b01 : 0);
+        MAX77650_setBRT_LED1(val);
+    }
+    if(led == 2) {
+        MAX77650_setLED_FS2(val > 0 ? 0b01 : 0);
+        MAX77650_setBRT_LED2(val);
+    }
+
+}
+
 // *****************************************************************************
 int main(void)
 {
@@ -160,11 +225,24 @@ int main(void)
         printf("%02x: 0x%06x\n", i, val);
     }
 
+    pmic_init();
+
     while (1) {
-        LED_On(0);
+        set_led(0, 33);
+        set_led(1, 0);
+        set_led(2, 0);
         TMR_Delay(MXC_TMR0, MSEC(500), 0);
-        LED_Off(0);
+
+        set_led(0, 0);
+        set_led(1, 33);
+        set_led(2, 0);
+        TMR_Delay(MXC_TMR0, MSEC(500), 0);
+
+        set_led(0, 0);
+        set_led(1, 0);
+        set_led(2, 33);
         TMR_Delay(MXC_TMR0, MSEC(500), 0);
+
         printf("count = %d\n", count++);
     }
 }
-- 
GitLab