for textbook v4.4
Dependencies: HEPTA_SENSOR mbed HEPTA_EPS HEPTA_COM HEPTA_CDH
main.cpp
- Committer:
- HeptaSatTraining2019
- Date:
- 2019-08-21
- Revision:
- 26:220e5f95168a
- Parent:
- 25:ccc5ff675e0c
- Child:
- 27:6f3dec57c1d5
File content as of revision 26:220e5f95168a:
#include "mbed.h" #include "HEPTA_CDH.h" #include "HEPTA_EPS.h" Serial pc(USBTX,USBRX); HEPTA_CDH cdh(p5, p6, p7, p8, "sd"); HEPTA_EPS eps(p16,p26); DigitalOut myleds[] = {LED1,LED2,LED3,LED4};; int rcmd = 0,cmdflag = 0; void commandget() { rcmd=pc.getc(); cmdflag = 1; } void receive(int *xrcmd, int *xcmdflag) { pc.attach(commandget,Serial::RxIrq); *xrcmd = rcmd; *xcmdflag = cmdflag; } void initialize() { rcmd = 0; cmdflag = 0; } int main() { pc.baud(9600); float bt; int flag = 0; char str[100]; receive(&rcmd,&cmdflag); while(1) { eps.vol(&bt); if(bt <= 3.5) { eps.shut_down_regulator(); flag = 1; } else { eps.turn_on_regulator(); flag = 0; } pc.printf("Vol = %.2f [V]\r\n",bt); if(flag == 1) { pc.printf("Power saving mode ON\r\n"); } wait(0.5); if (cmdflag == 1) { pc.printf("Command Get = %d\r\n",rcmd); if (rcmd == 'a') { for(int i = 0; i < 10; i++) { pc.printf("Count = %d\r\n",i); wait(1.0); } } if (rcmd == 'b') { } initialize(); } } }