diff --git a/core/include/hwtimer.h b/core/include/hwtimer.h
index 8b588e55256e1ec7b20b1e8c32753b3b2a01c024..0a92b14d34cbd4f270f2be23c9c4c0b6f838be2e 100644
--- a/core/include/hwtimer.h
+++ b/core/include/hwtimer.h
@@ -17,8 +17,8 @@
  * interrupt context and must use the shortest possible execution time (e.g.
  * set a flag and trigger a worker thread).
  *
- * <b>The hardware timer must not be used within applications</b>, use \ref vtimer
- * instead.
+ * <b>The hardware timer should not be used (until you know what
+ * you're doing)<b>, use \ref sys_vtimer instead.
  *
  * @{
  *
@@ -38,15 +38,15 @@
 #include "hwtimer_cpu.h"
 
 /**
- * @def    HWTIMER_SPEED
- * @brief    Number of kernel timer ticks per second
+ * @brief   Number of kernel timer ticks per second
+ * @def     HWTIMER_SPEED
  */
 #ifndef HWTIMER_SPEED
 #warning "HWTIMER_SPEED undefined. Set HWTIMER_SPEED to number of ticks per second for the current architecture."
 #endif
 
 /**
- * @brief   Convert microseconds to kernel timer ticks
+ * @brief       Convert microseconds to kernel timer ticks
  * @param[in]   us number of microseconds
  * @return      kernel timer ticks
  */
@@ -60,22 +60,24 @@
 #define HWTIMER_TICKS_TO_US(ticks)        ((ticks) * (1000000L/HWTIMER_SPEED))
 
 /**
- * @def    HWTIMER_MAXTICKS
- * @brief    Maximum hwtimer tick count (before overflow)
+ * @brief   Maximum hwtimer tick count (before overflow)
+ * @def     HWTIMER_MAXTICKS
  */
 #ifndef HWTIMER_MAXTICKS
 #warning "HWTIMER_MAXTICKS undefined. Set HWTIMER_MAXTICKS to maximum number of ticks countable on the current architecture."
 #endif
 
 /**
- * @brief    microseconds before hwtimer overflow
+ * @brief   microseconds before hwtimer overflow
  */
 #define HWTIMER_OVERFLOW_MICROS()        (1000000L / HWTIMER_SPEED * HWTIMER_MAXTICKS)
 
-typedef uint32_t timer_tick_t;
+typedef uint32_t timer_tick_t; /**< data type for hwtimer ticks */
 
+/**
+ * @brief   initialize the hwtimer module
+ */
 void hwtimer_init(void);
-void hwtimer_init_comp(uint32_t fcpu);
 
 /**
  * @brief   Get the hardware time
@@ -85,51 +87,54 @@ unsigned long hwtimer_now(void);
 
 /**
  * @brief Set a kernel timer
- * @param[in]    offset        Offset until callback invocation in timer ticks
- * @param[in]    callback    Callback function
- * @param[in]    ptr            Argument to callback function
- * @return        timer id
+ * @param[in]   offset      Offset until callback invocation in timer ticks
+ * @param[in]   callback    Callback function
+ * @param[in]   ptr         Argument to callback function
+ * @return      timer id
  */
 int hwtimer_set(unsigned long offset, void (*callback)(void*), void *ptr);
 
 /**
  * @brief Set a kernel timer
- * @param[in]    absolute    Absolute timer counter value for invocation of handler
- * @param[in]    callback    Callback function
- * @param[in]    ptr            Argument to callback function
- * @return        timer id
+ * @param[in]   absolute    Absolute timer counter value for invocation of handler
+ * @param[in]   callback    Callback function
+ * @param[in]   ptr         Argument to callback function
+ * @return      timer id
  */
 int hwtimer_set_absolute(unsigned long absolute, void (*callback)(void*), void *ptr);
 
 /**
  * @brief Remove a kernel timer
- * @param[in]    t            Id of timer to remove
- * @retval    1 on success
+ * @param[in]   t   Id of timer to remove
+ * @return      1 on success
  */
 int hwtimer_remove(int t);
 
 /**
- * @brief    Delay current thread
- * @param[in]    ticks        Number of kernel ticks to delay
+ * @brief        Delay current thread
+ * @param[in]    ticks  Number of kernel ticks to delay
  */
 void hwtimer_wait(unsigned long ticks);
 
 /**
- * @brief    Delay current thread, spinning. Use only in interrupts for VERY short delays!
- * @param[in]    ticks        Number of kernel ticks to delay
+ * @brief   determine if the hwtimer module is initialized
+ * @return  1 if the hwtimer module is initialized
  */
-void hwtimer_spin(unsigned long ticks);
-
 int hwtimer_active(void);
 
-/** @} */
+/**
+ * @brief       initialize hwtimer module data structures and hardware
+ *
+ * @param[in]   fcpu        cpu frequency
+ */
+void hwtimer_init_comp(uint32_t fcpu);
 
-/* internal */
 /**
- * @brief    TODO
- * @internal
+ * @brief       Delay current thread, spinning. Use only in interrupts for VERY short delays!
+ *
+ * @param[in]   ticks        Number of kernel ticks to delay
  */
-void hwtimer_cpu_init(void (*handler)(int), uint32_t fcpu);
+void hwtimer_spin(unsigned long ticks);
 
 /** @} */
 #endif /* __HWTIMER_H */
diff --git a/core/include/hwtimer_arch.h b/core/include/hwtimer_arch.h
index 3167e586eab8f1697e74c3a09572b9517889dc5d..e533134fc4bdccdef6647227121be27ab90c7f9f 100644
--- a/core/include/hwtimer_arch.h
+++ b/core/include/hwtimer_arch.h
@@ -17,6 +17,7 @@
  * @author      Thomas Hillebrandt <hillebra@inf.fu-berlin.de>
  * @author      Heiko Will <hwill@inf.fu-berlin.de>
  * @author      Kaspar Schleiser <kaspar@schleiser.de>
+ * @}
  */
 
 #ifndef HWTIMER_ARCH_H_
@@ -25,40 +26,52 @@
 #include <stdint.h>
 
 /**
- * Initialize architecture dependent kernel timer support.
+ * @brief Initialize architecture dependent kernel timer support.
+ *
+ * @param[in] handler   callback function for the interrupt handler
+ * @param[in] fcpu      cpu frequency
  */
 void hwtimer_arch_init(void (*handler)(int), uint32_t fcpu);
 
 /**
- * Enable interrupts of hardware timers.
+ * @brief Enable interrupts of hardware timers.
  */
 void hwtimer_arch_enable_interrupt(void);
 
 /**
- * Disable interrupts of hardware timers.
+ * @brief Disable interrupts of hardware timers.
  */
 void hwtimer_arch_disable_interrupt(void);
 
 /**
- * Set a kernel timer to raise an interrupt after ::offset kernel timer ticks
- * from now.
+ * @brief Set a kernel timer to raise an interrupt after `offset` kernel timer
+ * ticks from now.
+ *
+ * @param[in] offset    number of ticks
+ * @param[in] timer     hardware timer identifier
  */
 void hwtimer_arch_set(unsigned long offset, short timer);
 
 /**
- * Set a kernel timer to raise an interrupt at specified system time.
+ * @brief Set a kernel timer to raise an interrupt at specified system time.
+ *
+ * @param[in] value     system time
+ * @param[in] timer     hardware timer identifier
  */
 void hwtimer_arch_set_absolute(unsigned long value, short timer);
 
 /**
- * Unset the kernel timer with the given timer ID.
+ * @brief Unset the kernel timer with the given timer ID.
+ *
+ * @param[in] timer     hardware timer identifier
  */
 void hwtimer_arch_unset(short timer);
 
 /**
  * Get the current tick count of the default hardware timer.
+ *
+ * @return  The current tick count of the hardware timer
  */
 unsigned long hwtimer_arch_now(void);
 
-/** @} */
 #endif /* HWTIMER_ARCH_H_ */
diff --git a/core/include/io.h b/core/include/io.h
index dcc2d62bb07fd913772215baa73124884ecbd6bc..97e0f39895d406dd014a39618120c57ad19be942 100644
--- a/core/include/io.h
+++ b/core/include/io.h
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2013 Freie Universität Berlin
+ * Copyright (C) 2014 Freie Universität Berlin
  *
  * This file subject to the terms and conditions of the GNU Lesser General
  * Public License. See the file LICENSE in the top level directory for more
@@ -22,6 +22,12 @@
 #ifndef IO_H
 #define IO_H
 
+/**
+ * @brief   Firmware putstring implementation
+ *
+ * @param[in] data  charachters to be written
+ * @param[in] count number of charachters to be written
+ */
 int fw_puts(char *data, int count);
 
 /** @} */
diff --git a/core/include/queue.h b/core/include/queue.h
index 0760eae8d27f14f5f62086ab8756b36f93715979..a0e6aadfcc52f8852019a60b0bc83f68a26e7f2d 100644
--- a/core/include/queue.h
+++ b/core/include/queue.h
@@ -23,22 +23,79 @@
 #include <stdint.h>
 #include <inttypes.h>
 
-// mspgcc bug : PRIxxx macros not defined before mid-2011 versions
+/* mspgcc bug : PRIxxx macros not defined before mid-2011 versions */
+/**
+ * @brief   Macro for printing 32 bit format specifier
+ * @def     PRIu32
+ */
 #ifndef PRIu32
 #define PRIu32 "lu"
 #endif
 
+/**
+ * data type for queue nodes
+ */
 typedef struct queue_node_t {
-    struct queue_node_t *next;
-    unsigned int data;
-    uint32_t priority;
+    struct queue_node_t *next;  /**< next queue node */
+    unsigned int data;          /**< queue node data */
+    uint32_t priority;          /**< queue node priority */
 } queue_node_t;
 
+/**
+ * @brief attach `new_obj` to the tail of the queue (identified
+ * `root`)
+ *
+ * @param[in,out]   root    the queue's root
+ * @param[in]       new_obj the object to append
+ */
 void queue_add_tail(queue_node_t *root, queue_node_t *new_obj);
+
+/**
+ * @brief attach `new_obj` to `root` at the beginning
+ *
+ * @param[in,out]   root    the queue's root
+ * @param[in]       new_obj the object to prepend
+ */
 void queue_add_head(queue_node_t *root, queue_node_t *new_obj);
+
+/**
+ * @brief remove the queue's head
+ *
+ * @param[out]  root    the queue's root
+ *
+ * @return              the old head
+ */
 queue_node_t *queue_remove_head(queue_node_t *root);
+
+/**
+ * @brief insert `new_obj` into `root` based on its priority
+ *
+ * @details
+ * The new object will be appended after objects with the same priority.
+ *
+ * @param[in,out]   root    the queue's root
+ * @param[in]       new_obj the object to prepend
+ */
 void queue_priority_add(queue_node_t *root, queue_node_t *new_obj);
+
+/**
+ * @brief insert `new_obj` into `root` based on an arbitrary priority
+ *
+ * @details
+ * The new object will be appended after objects with the same priority.
+ *
+ * @param[in,out]   root    the queue's root
+ * @param[in]       new_obj the object to prepend
+ * @param[in]       cmp     a comparator function used to determine the priority
+ */
 void queue_priority_add_generic(queue_node_t *root, queue_node_t *new_obj, int(*cmp)(queue_node_t *, queue_node_t *)) ;
+
+/**
+ * @brief remove `node` from `root`
+ *
+ * @param[in,out]   root    the queue's root
+ * @param[in]       node    the node to remove
+ */
 void queue_remove(queue_node_t *root, queue_node_t *node);
 
 #if ENABLE_DEBUG