phase.c

Go to the documentation of this file.
00001 
00040 #include "hw/hw_phase.h"
00041 
00042 #include <cfg/macros.h>
00043 #include <cfg/compiler.h>
00044 
00045 #include <cpu/irq.h>
00046 #include <cpu/types.h>
00047 
00048 #include <drv/timer.h>
00049 #include <drv/phase.h>
00050 
00051 #include <math.h>
00052 
00053 #warning TODO:Generalize this moduele for all target supported.
00054 
00055 #if 0
00056 
00057 static Triac triacs[TRIAC_CNT];
00058 
00059 DB(bool phase_initialized;)
00060 
00068 DEFINE_ZEROCROSS_ISR()
00069 {
00070     ticks_t period, now;
00071     static ticks_t prev_time;
00072     TriacDev dev;
00073 
00074     now = timer_clock_unlocked();
00075     period = now - prev_time;
00076 
00077     for (dev = 0; dev < TRIAC_CNT; dev++)
00078     {
00079         /* Only turn off triac if duty is != 100% */
00080         if (triacs[dev].duty != TRIAC_MAX_DUTY)
00081             TRIAC_OFF(dev);
00082         /* Compute delay from duty */
00083         timer_setDelay(&triacs[dev].timer, DIV_ROUND(period * (TRIAC_MAX_DUTY - triacs[dev].duty), TRIAC_MAX_DUTY));
00084 
00085         /* This check avoids inserting the same timer twice
00086          * in case of an intempestive zerocross or spike */
00087         if (triacs[dev].running)
00088         {
00089             timer_abort(&triacs[dev].timer);
00090             //kprintf("[%lu]\n", timer_clock());
00091         }
00092 
00093         triacs[dev].running = true;
00094         timer_add(&triacs[dev].timer);
00095     }
00096     prev_time = now;
00097 }
00098 
00099 
00100 
00104 void phase_setDuty(TriacDev dev, triac_duty_t duty)
00105 {
00106     cpu_flags_t flags;
00107     IRQ_SAVE_DISABLE(flags);
00108 
00109     phase_setDutyUnlock(dev,duty);
00110 
00111     IRQ_RESTORE(flags);
00112 }
00113 
00114 
00115 
00119 void phase_setDutyUnlock(TriacDev dev, triac_duty_t duty)
00120 {
00121     triacs[dev].duty = MIN(duty, (triac_duty_t)TRIAC_MAX_DUTY);
00122 }
00123 
00124 
00125 
00132 void phase_setPower(TriacDev dev, triac_power_t power)
00133 {
00134     bool greater_fifty = false;
00135     triac_duty_t duty;
00136 
00137     power = MIN(power, (triac_power_t)TRIAC_MAX_POWER);
00138 
00139     if (power > TRIAC_MAX_POWER / 2)
00140     {
00141         greater_fifty = true;
00142         power = TRIAC_MAX_POWER - power;
00143     }
00144 
00145     duty = TRIAC_POWER_K * sqrt(power);
00146 
00147     if (greater_fifty)
00148         duty = TRIAC_MAX_DUTY - duty;
00149     phase_setDuty(dev, duty);
00150 }
00151 
00152 
00153 
00159 static void phase_softint(void *_dev)
00160 {
00161     TriacDev dev = (TriacDev)_dev;
00162 
00163     /* Only turn on if duty is !=0 */
00164     if (triacs[dev].duty)
00165         TRIAC_ON(dev);
00166     triacs[dev].running = false;
00167 }
00168 
00169 
00170 
00174 void phase_init(void)
00175 {
00176     cpu_flags_t flags;
00177     TriacDev dev;
00178 
00179     /* Init timers and ensure that all triac are off */
00180     for (dev = 0; dev < TRIAC_CNT; dev++)
00181     {
00182         triacs[dev].duty = 0;
00183         triacs[dev].running = false;
00184         SET_TRIAC_DDR(dev);
00185         TRIAC_OFF(dev);
00186         timer_set_event_softint(&triacs[dev].timer, (Hook)phase_softint, (void *)dev);
00187     }
00188     IRQ_SAVE_DISABLE(flags);
00189 
00190     /* Init zero cross interrupt */
00191     PHASE_HW_INIT;
00192     DB(phase_initialized = true;)
00193     IRQ_RESTORE(flags);
00194 }
00195 #endif
00196