Mercurial > public > ostc4
comparison Discovery/Src/data_exchange_main.c @ 295:718e5feded62
Merged in janlmulder/ostc4/div-fixes-6 (pull request #23)
Cleanup VPM, NDL to 240 min, and more cleanup
author | heinrichsweikamp <bitbucket@heinrichsweikamp.com> |
---|---|
date | Mon, 13 May 2019 13:37:34 +0000 |
parents | ba229a012ac7 |
children | 2f43419102c8 |
comparison
equal
deleted
inserted
replaced
287:ba9d99a2e310 | 295:718e5feded62 |
---|---|
420 } | 420 } |
421 | 421 |
422 | 422 |
423 void DataEX_copy_to_deco(void) | 423 void DataEX_copy_to_deco(void) |
424 { | 424 { |
425 SDiveState * pStateUsed; | |
426 if(decoLock == DECO_CALC_running) | 425 if(decoLock == DECO_CALC_running) |
427 return; | 426 return; |
428 if(stateUsed == stateRealGetPointer()) | |
429 pStateUsed = stateRealGetPointerWrite(); | |
430 else{ | |
431 pStateUsed = stateSimGetPointerWrite(); | |
432 } | |
433 | 427 |
434 if(decoLock == DECO_CALC_init_as_is_start_of_dive) | 428 if(decoLock == DECO_CALC_init_as_is_start_of_dive) |
435 { | 429 { |
436 vpm_init(&pStateUsed->vpm, pStateUsed->diveSettings.vpm_conservatism, 0, 0); | 430 vpm_init(&stateUsedWrite->vpm, stateUsedWrite->diveSettings.vpm_conservatism, 0, 0); |
437 buehlmann_init(); | 431 buehlmann_init(); |
438 timer_init(); | 432 timer_init(); |
439 resetEvents(pStateUsed); | 433 resetEvents(stateUsedWrite); |
440 pStateUsed->diveSettings.internal__pressure_first_stop_ambient_bar_as_upper_limit_for_gf_low_otherwise_zero = 0; | 434 stateUsedWrite->diveSettings.internal__pressure_first_stop_ambient_bar_as_upper_limit_for_gf_low_otherwise_zero = 0; |
441 /* | |
442 * ToDo by Peter | |
443 * copy VPM stuff etc. pp. | |
444 * was void initDiveState(SDiveSettings * pDiveSettings, SVpm * pVpm); | |
445 */ | |
446 } | 435 } |
447 | 436 |
448 if(decoLock == DECO_CALC_FINSHED_Buehlmann) | 437 if(decoLock == DECO_CALC_FINSHED_Buehlmann) |
449 { | 438 { |
450 | 439 |
452 switch(decoLock) | 441 switch(decoLock) |
453 { | 442 { |
454 | 443 |
455 //Deco_calculation finished | 444 //Deco_calculation finished |
456 case DECO_CALC_FINSHED_vpm: | 445 case DECO_CALC_FINSHED_vpm: |
457 memcpy(&pStateUsed->decolistVPM,&stateDeco.decolistVPM,sizeof(SDecoinfo)); | 446 memcpy(&stateUsedWrite->decolistVPM,&stateDeco.decolistVPM,sizeof(SDecoinfo)); |
458 pStateUsed->decolistVPM.tickstamp = HAL_GetTick(); | 447 stateUsedWrite->decolistVPM.tickstamp = HAL_GetTick(); |
459 pStateUsed->vpm.deco_zone_reached = stateDeco.vpm.deco_zone_reached; | 448 stateUsedWrite->vpm.deco_zone_reached = stateDeco.vpm.deco_zone_reached; |
460 for(int i = 0; i< 16; i++) | 449 for(int i = 0; i< 16; i++) |
461 { | 450 { |
462 pStateUsed->vpm.adjusted_critical_radius_he[i] = stateDeco.vpm.adjusted_critical_radius_he[i]; | 451 stateUsedWrite->vpm.adjusted_critical_radius_he[i] = stateDeco.vpm.adjusted_critical_radius_he[i]; |
463 pStateUsed->vpm.adjusted_critical_radius_n2[i] = stateDeco.vpm.adjusted_critical_radius_n2[i]; | 452 stateUsedWrite->vpm.adjusted_critical_radius_n2[i] = stateDeco.vpm.adjusted_critical_radius_n2[i]; |
464 pStateUsed->vpm.adjusted_crushing_pressure_he[i] = stateDeco.vpm.adjusted_crushing_pressure_he[i]; | 453 stateUsedWrite->vpm.adjusted_crushing_pressure_he[i] = stateDeco.vpm.adjusted_crushing_pressure_he[i]; |
465 pStateUsed->vpm.adjusted_crushing_pressure_n2[i] = stateDeco.vpm.adjusted_crushing_pressure_n2[i]; | 454 stateUsedWrite->vpm.adjusted_crushing_pressure_n2[i] = stateDeco.vpm.adjusted_crushing_pressure_n2[i]; |
466 pStateUsed->vpm.initial_allowable_gradient_he[i] = stateDeco.vpm.initial_allowable_gradient_he[i]; | 455 stateUsedWrite->vpm.initial_allowable_gradient_he[i] = stateDeco.vpm.initial_allowable_gradient_he[i]; |
467 pStateUsed->vpm.initial_allowable_gradient_n2[i] = stateDeco.vpm.initial_allowable_gradient_n2[i]; | 456 stateUsedWrite->vpm.initial_allowable_gradient_n2[i] = stateDeco.vpm.initial_allowable_gradient_n2[i]; |
468 pStateUsed->vpm.max_actual_gradient[i] = stateDeco.vpm.max_actual_gradient[i]; | 457 stateUsedWrite->vpm.max_actual_gradient[i] = stateDeco.vpm.max_actual_gradient[i]; |
469 } | 458 } |
470 break; | 459 break; |
471 case DECO_CALC_FINSHED_Buehlmann: | 460 case DECO_CALC_FINSHED_Buehlmann: |
472 memcpy(&pStateUsed->decolistBuehlmann,&stateDeco.decolistBuehlmann,sizeof(SDecoinfo)); | 461 memcpy(&stateUsedWrite->decolistBuehlmann,&stateDeco.decolistBuehlmann,sizeof(SDecoinfo)); |
473 pStateUsed->decolistBuehlmann.tickstamp = HAL_GetTick(); | 462 stateUsedWrite->decolistBuehlmann.tickstamp = HAL_GetTick(); |
474 //Copy Data to be stored if regular Buehlmann, not FutureBuehlmann | 463 //Copy Data to be stored if regular Buehlmann, not FutureBuehlmann |
475 pStateUsed->diveSettings.internal__pressure_first_stop_ambient_bar_as_upper_limit_for_gf_low_otherwise_zero = stateDeco.diveSettings.internal__pressure_first_stop_ambient_bar_as_upper_limit_for_gf_low_otherwise_zero; | 464 stateUsedWrite->diveSettings.internal__pressure_first_stop_ambient_bar_as_upper_limit_for_gf_low_otherwise_zero = stateDeco.diveSettings.internal__pressure_first_stop_ambient_bar_as_upper_limit_for_gf_low_otherwise_zero; |
476 break; | 465 break; |
477 case DECO_CALC_FINSHED_FutureBuehlmann: | 466 case DECO_CALC_FINSHED_FutureBuehlmann: |
478 memcpy(&pStateUsed->decolistFutureBuehlmann,&stateDeco.decolistFutureBuehlmann,sizeof(SDecoinfo)); | 467 memcpy(&stateUsedWrite->decolistFutureBuehlmann,&stateDeco.decolistFutureBuehlmann,sizeof(SDecoinfo)); |
479 pStateUsed->decolistFutureBuehlmann.tickstamp = HAL_GetTick(); | 468 stateUsedWrite->decolistFutureBuehlmann.tickstamp = HAL_GetTick(); |
480 break; | 469 break; |
481 case DECO_CALC_FINSHED_Futurevpm: | 470 case DECO_CALC_FINSHED_Futurevpm: |
482 memcpy(&pStateUsed->decolistFutureVPM,&stateDeco.decolistFutureVPM,sizeof(SDecoinfo)); | 471 memcpy(&stateUsedWrite->decolistFutureVPM,&stateDeco.decolistFutureVPM,sizeof(SDecoinfo)); |
483 pStateUsed->decolistFutureVPM.tickstamp = HAL_GetTick(); | 472 stateUsedWrite->decolistFutureVPM.tickstamp = HAL_GetTick(); |
484 break; | 473 break; |
485 } | 474 } |
486 | 475 |
487 //Copy Inputdata from stateReal to stateDeco | 476 //Copy Inputdata from stateReal to stateDeco |
488 memcpy(&stateDeco.lifeData,&pStateUsed->lifeData,sizeof(SLifeData)); | 477 memcpy(&stateDeco.lifeData,&stateUsedWrite->lifeData,sizeof(SLifeData)); |
489 memcpy(&stateDeco.diveSettings,&pStateUsed->diveSettings,sizeof(SDiveSettings)); | 478 memcpy(&stateDeco.diveSettings,&stateUsedWrite->diveSettings,sizeof(SDiveSettings)); |
490 | 479 |
491 stateDeco.vpm.deco_zone_reached = pStateUsed->vpm.deco_zone_reached; | 480 stateDeco.vpm.deco_zone_reached = stateUsedWrite->vpm.deco_zone_reached; |
492 // memcpy(&stateDeco.vpm,&pStateUsed->vpm,sizeof(SVpm)); | 481 // memcpy(&stateDeco.vpm,&pStateUsed->vpm,sizeof(SVpm)); |
493 for(int i = 0; i< 16; i++) | 482 for(int i = 0; i< 16; i++) |
494 { | 483 { |
495 stateDeco.vpm.max_crushing_pressure_he[i] = pStateUsed->vpm.max_crushing_pressure_he[i]; | 484 stateDeco.vpm.max_crushing_pressure_he[i] = stateUsedWrite->vpm.max_crushing_pressure_he[i]; |
496 stateDeco.vpm.max_crushing_pressure_n2[i] = pStateUsed->vpm.max_crushing_pressure_n2[i]; | 485 stateDeco.vpm.max_crushing_pressure_n2[i] = stateUsedWrite->vpm.max_crushing_pressure_n2[i]; |
497 stateDeco.vpm.adjusted_critical_radius_he[i] = pStateUsed->vpm.adjusted_critical_radius_he[i]; | 486 stateDeco.vpm.adjusted_critical_radius_he[i] = stateUsedWrite->vpm.adjusted_critical_radius_he[i]; |
498 stateDeco.vpm.adjusted_critical_radius_n2[i] = pStateUsed->vpm.adjusted_critical_radius_n2[i]; | 487 stateDeco.vpm.adjusted_critical_radius_n2[i] = stateUsedWrite->vpm.adjusted_critical_radius_n2[i]; |
499 } | 488 } |
500 decoLock = DECO_CALC_ready; | 489 decoLock = DECO_CALC_ready; |
501 } | 490 } |
502 | 491 |
503 | 492 |