FreeCalypso > hg > fc-tourmaline
diff src/cs/drivers/drv_app/lcc/lcc_modulate.c @ 0:4e78acac3d88
src/{condat,cs,gpf,nucleus}: import from Selenite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:23:26 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/cs/drivers/drv_app/lcc/lcc_modulate.c Fri Oct 16 06:23:26 2020 +0000 @@ -0,0 +1,88 @@ +/****************************************************************************** + * Power Task (pwr) + * Design and coding by Svend Kristian Lindholm, skl@ti.com + * + * PWR SW Modulation + * + * $Id: pwr_modulate.c 1.1 Wed, 20 Aug 2003 10:22:37 +0200 skl $ + * + ******************************************************************************/ +#include <string.h> +#include "lcc/lcc.h" +#include "lcc/lcc_trace.h" +#include "lcc/lcc_modulate.h" +#include "lcc/lcc_cfg_i.h" +#include "lcc/lcc_cfg.h" +#include "rv/rv_defined_swe.h" +#include "abb/abb.h" + +/****************************************************************************** + * Function prototypes + ******************************************************************************/ + +void pwr_modulate_init(void); +void pwr_modulate_on(void); +void pwr_modulate_off(void); + + +#if (USE_Q401_CHG_CIRCUIT == 1) +extern T_PWR_CFG_BLOCK *pwr_cfg; +#endif + +void pwr_modulate_init(void) { + ttw(ttr(TTrEventLow,"pwr_modulate_init(%d)" NL, 0)); + #if (USE_PWL_AS_MODULATOR == 1) + BUZZ_LIGHT_REG |= 0x02; + PWL_LEVEL_REG = 0xFF; // Full envelope function + PWL_CTRL_REG = 0x00; // No 32KHz clock + #else + // Set GPIO 6 HIGH + *((volatile uint16 *) 0xfffe4806) |= 0x0020; // Enable GPIO module + *((volatile uint16 *) 0xfffe4804) &= 0xffbf; // Set GPIO-6 = output + *((volatile uint16 *) 0xfffe4802) |= 0x0080; // Set GPIO-6 = HIGH + #endif + ttw(ttr(TTrEventLow,"pwr_modulate_init(%d)" NL, 0xff)); +} + +void pwr_modulate_on(void) { + ttw(ttr(TTrEventLow,"pwr_modulate_on(%d)" NL, 0)); +#if (USE_Q401_CHG_CIRCUIT== 1) + /* Program the DAC with the constant current value taken from /pwr/chg/chg<N>.cfg multiplied by k/255, where current k is in [1..255] */ + ABB_Write_Register_on_page(PAGE0, CHGREG, (pwr_cfg->data.k * pwr_cfg->chg.ichg_max) / 255); +#endif +#if (USE_Q402_CHG_CIRCUIT == 1) + #if (USE_PWL_AS_MODULATOR == 1) + BUZZ_LIGHT_REG |= 0x02; + PWL_LEVEL_REG = 0xFF; // Full envelope function + PWL_CTRL_REG = 0x00; // No 32KHz clock + #else + // Use GPIO 6 + *((volatile uint16 *) 0xfffe4806) |= 0x0020; // Enable GPIO module + *((volatile uint16 *) 0xfffe4804) &= 0xffbf; // Set GPIO-6 = output + *((volatile uint16 *) 0xfffe4802) |= 0x0080; // Set GPIO-6 = HIGH + #endif +#endif + ttw(ttr(TTrEventLow,"pwr_modulate_on(%d)" NL, 0xFF)); + +} + +void pwr_modulate_off(void) { + ttw(ttr(TTrEventLow,"pwr_modulate_off(%d)" NL, 0)); +#if (USE_Q401_CHG_CIRCUIT == 1) + // Don't do anything - FET is fully controlled in pwr_modulate_on() +#endif +#if (USE_Q402_CHG_CIRCUIT == 1) + #ifdef USE_PWL_AS_MODULATOR + BUZZ_LIGHT_REG &= 0xfd; + PWL_LEVEL_REG = 0x00; // No envelope function + PWL_CTRL_REG = 0x00; // No 32KHz clock + #else + // Use GPIO 6 + *((volatile uint16 *) 0xfffe4806) |= 0x0020; // Enable GPIO module + *((volatile uint16 *) 0xfffe4804) &= 0xffbf; // Set GPIO-6 = output + *((volatile uint16 *) 0xfffe4802) &= 0x007f; // Set GPIO-6 = LOW + #endif +#endif + ttw(ttr(TTrEventLow,"pwr_modulate_off(%d)" NL, 0xFF)); +} +