4 * Copyright 2004 Develer S.r.l. (http://www.develer.com/)
5 * Copyright 2004 Giovanni Bajo
6 * This file is part of DevLib - See devlib/README for information.
9 * \brief Generic library to handle buzzers and leds
11 * This library is divided into three different layers:
13 * - The topmost portable layer is buzzerled.[ch] which exposes a common API
14 * enable/disable the devices. Basically, it handles the asynchronism to
15 * implement bld_beep and bld_repeat.
16 * - The middle layer is CPU-specific and exposes a single main function which
17 * turns on/off each device.
18 * - The lower layer is board-specific and communicates with the middle layer
19 * with any required API. The idea is that devices can be tied to the CPU in
20 * many different ways (many different pins), so this part should describe
21 * which devices are present, and how they are connected.
25 * \author Giovanni Bajo <rasky@develer.com>
30 * Revision 1.3 2004/07/14 14:04:29 rasky
31 * Merge da SC: spostata bld_set inline perché si ottimizza parecchio tramite propagazione di costanti
33 * Revision 1.2 2004/06/03 11:27:09 bernie
34 * Add dual-license information.
36 * Revision 1.1 2004/05/23 18:36:05 bernie
37 * Import buzzerled driver.
41 #include "buzzerled.h"
44 static struct Timer timers[NUM_BLDS];
45 static bool timer_go[NUM_BLDS];
47 INLINE enum BLD_DEVICE hook_parm_to_device(void* parm)
49 struct Timer* t = (struct Timer*)parm;
50 int num_bld = t - &timers[0];
53 ASSERT(num_bld < NUM_BLDS);
55 return (enum BLD_DEVICE)num_bld;
58 static void hook_turn_off(void* parm)
60 enum BLD_DEVICE num_bld = hook_parm_to_device(parm);
61 bld_set(num_bld, false);
69 void bld_beep(enum BLD_DEVICE device, uint16_t duration)
71 struct Timer* t = &timers[device];
72 timer_set_delay(t, duration);
73 timer_set_event_softint(t, hook_turn_off, t);
76 bld_set(device, true);
79 void bld_beep_and_wait(enum BLD_DEVICE device, uint16_t duration)
81 bld_set(device, true);
82 timer_delay(duration);
83 bld_set(device, false);