1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-29 14:52:12 +01:00

OP-21/Flight Bootloader - Added more Led status modes. Fixed downloading for bigger packet format.

git-svn-id: svn://svn.openpilot.org/OpenPilot/trunk@1436 ebee16cc-31ac-478f-84a7-5cbb03baadba
This commit is contained in:
zedamota 2010-08-27 20:03:51 +00:00 committed by zedamota
parent 16361dea12
commit 2142467751
2 changed files with 102 additions and 33 deletions

View File

@ -32,9 +32,11 @@ typedef void (*pFunction)(void);
pFunction Jump_To_Application;
uint32_t JumpAddress;
uint32_t cnt;
uint32_t pwm_period;
uint32_t pwm_sweep_steps;
/// LEDs PWM
uint32_t period1 = 50; // *100 uS -> 5 mS
uint32_t sweep_steps1 = 100; // * 5 mS -> 500 mS
uint32_t period2 = 50; // *100 uS -> 5 mS
uint32_t sweep_steps2 = 100; // * 5 mS -> 500 mS
/* Extern variables ----------------------------------------------------------*/
uint8_t DeviceState;
@ -42,6 +44,7 @@ uint8_t JumpToApp = 0;
/* Private function prototypes -----------------------------------------------*/
void Delay(__IO uint32_t nCount);
void DelayWithDown(__IO uint32_t nCount);
uint32_t LedPWM(uint32_t pwm_period, uint32_t pwm_sweep_steps, uint32_t count);
/* Private functions ---------------------------------------------------------*/
/*******************************************************************************
@ -54,37 +57,76 @@ void DelayWithDown(__IO uint32_t nCount);
int main(void) {
Set_System();
if (BSL_HOLD_STATE==0) {
if (BSL_HOLD_STATE == 0) {
USB_Interrupts_Config();
Set_USBClock();
USB_Init();
DeviceState = idle;
STOPWATCH_Init(100);
}
else
} else
JumpToApp = TRUE;
STOPWATCH_Reset();
while (JumpToApp == 0) {
cnt = STOPWATCH_ValueGet(); // the reference counter (incremented each 100 uS)
pwm_period = 50; // *100 uS -> 5 mS
pwm_sweep_steps =100; // * 5 mS -> 500 mS
uint32_t pwm_duty = ((cnt / pwm_period) % pwm_sweep_steps)
/ (pwm_sweep_steps / pwm_period);
if ((cnt % (2 * pwm_period * pwm_sweep_steps)) > pwm_period
* pwm_sweep_steps)
pwm_duty = pwm_period - pwm_duty; // negative direction each 50*100 ticks
uint32_t led_on = ((cnt % pwm_period) > pwm_duty) ? 1 : 0;
if(led_on==0)
//pwm_period = 50; // *100 uS -> 5 mS
//pwm_sweep_steps =100; // * 5 mS -> 500 mS
switch (DeviceState) {
case Last_operation_Success:
case uploadingStarting:
case DFUidle:
period1 = 50;
sweep_steps1 = 100;
STM_EVAL_LEDOff(LED2);
period2 = 0;
break;
case uploading:
period1 = 50;
sweep_steps1 = 100;
period2 = 25;
sweep_steps2 = 50;
break;
case downloading:
period1 = 25;
sweep_steps1 = 50;
STM_EVAL_LEDOff(LED2);
period2 = 0;
break;
case idle:
period1 = 0;
STM_EVAL_LEDOn(LED1);
else
STM_EVAL_LEDOff(LED1);
if(STOPWATCH_ValueGet()>100*pwm_period*pwm_sweep_steps)
period2=0;
break;
default://error
period1 = 50;
sweep_steps1 = 100;
period2 = 50;
sweep_steps2 = 100;
}
if (period1 != 0) {
if (LedPWM(period1, sweep_steps1, STOPWATCH_ValueGet()))
STM_EVAL_LEDOn(LED1);
else
STM_EVAL_LEDOff(LED1);
} else
STM_EVAL_LEDOn(LED1);
if (period2 != 0) {
if (LedPWM(period2, sweep_steps2, STOPWATCH_ValueGet()))
STM_EVAL_LEDOn(LED2);
else
STM_EVAL_LEDOff(LED2);
} else
STM_EVAL_LEDOff(LED2);
if (STOPWATCH_ValueGet() > 100 * 50 * 100)
STOPWATCH_Reset();
if(STOPWATCH_ValueGet()>50000 && DeviceState == idle)
JumpToApp=TRUE;
if ((STOPWATCH_ValueGet() > 60000) && (DeviceState == idle))
JumpToApp = TRUE;
FLASH_Download();
//DelayWithDown(10);//1000000);
}
if (((*(__IO uint32_t*) StartOfUserCode) & 0x2FFE0000) == 0x20000000) { /* Jump to user application */
@ -104,12 +146,27 @@ int main(void) {
}
while (1) {
STM_EVAL_LEDToggle(LED1);
STM_EVAL_LEDToggle(LED2);
Delay(1000000);
if (LedPWM(50, 100, STOPWATCH_ValueGet())) {
STM_EVAL_LEDOn(LED2);
STM_EVAL_LEDOff(LED1);
} else {
STM_EVAL_LEDOn(LED1);
STM_EVAL_LEDOff(LED2);
}
if (STOPWATCH_ValueGet() > 2*50 * 100)
STOPWATCH_Reset();
FLASH_Download();
}
}
}
uint32_t LedPWM(uint32_t pwm_period, uint32_t pwm_sweep_steps, uint32_t count) {
uint32_t pwm_duty = ((count / pwm_period) % pwm_sweep_steps)
/ (pwm_sweep_steps / pwm_period);
if ((count % (2 * pwm_period * pwm_sweep_steps)) > pwm_period
* pwm_sweep_steps)
pwm_duty = pwm_period - pwm_duty; // negative direction each 50*100 ticks
return ((count % pwm_period) > pwm_duty) ? 1 : 0;
}
/*******************************************************************************
* Function Name : Delay
* Description : Inserts a delay time.

View File

@ -52,7 +52,7 @@ uint32_t aux;
volatile uint32_t downPacketCurrent=0;
uint32_t downPacketTotal=0;
uint8_t downType=0;
uint32_t downSizeOfLastPacket=0;
uint32_t MemLocations[3]=
{
StartOfUserCode, StartOfUserCode-SizeOfHash, StartOfUserCode-SizeOfHash-SizeOfDescription
@ -67,22 +67,34 @@ uint8_t *FLASH_If_Read (uint32_t SectorAddress, uint32_t DataLength)
return (uint8_t*)(SectorAddress);
}
void FLASH_Download() {
if (DeviceState == downloading) {
if ((DeviceState == downloading) && (GetEPTxStatus(ENDP1)==EP_TX_NAK)) {
uint8_t packetSize;
Buffer[0] = 0x01;
Buffer[1] = Download;
Buffer[2] = downPacketCurrent >> 24;
Buffer[3] = downPacketCurrent >> 16;
Buffer[4] = downPacketCurrent >> 8;
Buffer[5] = downPacketCurrent;
Buffer[6] = *FLASH_If_Read(MemLocations[downType]+downPacketCurrent*4, 0);
Buffer[7] = *FLASH_If_Read(MemLocations[downType] + 1+downPacketCurrent*4, 0);
Buffer[8] = *FLASH_If_Read(MemLocations[downType] + 2+downPacketCurrent*4, 0);
Buffer[9] = *FLASH_If_Read(MemLocations[downType] + 3+downPacketCurrent*4, 0);
if(downPacketCurrent==downPacketTotal)
{
packetSize=downSizeOfLastPacket;
}
else
{
packetSize=14;
}
for(int x=0;x<packetSize;++x)
{
Buffer[6+x*4] = *FLASH_If_Read(MemLocations[downType]+ downPacketCurrent*4+x*4, 0);
Buffer[7+x*4] = *FLASH_If_Read(MemLocations[downType] + 1+downPacketCurrent*4+x*4, 0);
Buffer[8+x*4] = *FLASH_If_Read(MemLocations[downType] + 2+downPacketCurrent*4+x*4, 0);
Buffer[9+x*4] = *FLASH_If_Read(MemLocations[downType] + 3+downPacketCurrent*4+x*4, 0);
}
USB_SIL_Write(EP1_IN, (uint8_t*) Buffer, 64);
downPacketCurrent=downPacketCurrent+1;
if(downPacketCurrent>downPacketTotal)
{
STM_EVAL_LEDOn(LED2);
// STM_EVAL_LEDOn(LED2);
DeviceState=Last_operation_Success;
Aditionals=(uint32_t)Download;
}
@ -103,7 +115,6 @@ void EP1_OUT_Callback(void)
/* Read received data (2 bytes) */
USB_SIL_Read(EP1_OUT, Receive_Buffer);
Command=Receive_Buffer[1];
EchoReqFlag=(Command>>7);
EchoAnsFlag=(Command>>6) & 0x01;
@ -225,6 +236,7 @@ void EP1_OUT_Callback(void)
downPacketCurrent=0;
downPacketTotal=Count;
DeviceState=downloading;
downSizeOfLastPacket=Data1;
}
else
{