/*#*
*#* $Log$
+ *#* Revision 1.35 2007/01/27 20:47:12 batt
+ *#* Add clear status.
+ *#*
+ *#* Revision 1.34 2006/11/20 15:07:40 batt
+ *#* Revert unneeded locked functions.
+ *#*
+ *#* Revision 1.33 2006/11/17 17:03:58 batt
+ *#* Implement ser_setstatus and ser_getstatus as functions to avoid race conditions.
+ *#*
+ *#* Revision 1.32 2006/11/17 16:01:12 batt
+ *#* Serial status MUST be volatile.
+ *#*
+ *#* Revision 1.31 2006/09/13 18:22:48 bernie
+ *#* Typo.
+ *#*
+ *#* Revision 1.30 2006/09/13 18:21:23 bernie
+ *#* Add configurable SPI pin mapping.
+ *#*
*#* Revision 1.29 2006/09/13 13:59:11 bernie
*#* Documentation fixes.
*#*
#define SERRF_TX (SERRF_TXTIMEOUT)
/*\}*/
+/**
+ * \name LSB or MSB first data order, used with SPI AVR serial
+ * \{
+ */
+#define SER_MSB_FIRST 0
+#define SER_LSB_FIRST 1
+/*\}*/
/**
* \name Parity settings for ser_setparity().
*/
enum
{
-#if CPU_AVR_ATMEGA64 || CPU_AVR_ATMEGA128
+#if CPU_AVR_ATMEGA64 || CPU_AVR_ATMEGA128 || CPU_AVR_ATMEGA1281
SER_UART0,
SER_UART1,
SER_SPI,
#endif
/** Holds the flags defined above. Will be 0 when no errors have occurred. */
- serstatus_t status;
+ volatile serstatus_t status;
/** Low-level interface to hardware. */
struct SerialHardware* hw;
extern void ser_purge(struct Serial *port);
extern void ser_drain(struct Serial *port);
+extern void ser_clearstatus(struct Serial *port);
+
extern struct Serial *ser_open(unsigned int unit);
extern void ser_close(struct Serial *port);