projects
/
pub
/
USBasp.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add more missing function attributes to the TWI peripheral driver.
[pub/USBasp.git]
/
Projects
/
XPLAINBridge
/
Lib
/
SoftUART.c
diff --git
a/Projects/XPLAINBridge/Lib/SoftUART.c
b/Projects/XPLAINBridge/Lib/SoftUART.c
index
ddd983a
..
9ee103d
100644
(file)
--- a/
Projects/XPLAINBridge/Lib/SoftUART.c
+++ b/
Projects/XPLAINBridge/Lib/SoftUART.c
@@
-52,7
+52,7
@@
static uint8_t RX_BitsRemaining;
static uint8_t RX_Data;
static uint8_t RX_Data;
-/** Initiali
s
es the software UART, ready for data transmission and reception into the global ring buffers. */
+/** Initiali
z
es the software UART, ready for data transmission and reception into the global ring buffers. */
void SoftUART_Init(void)
{
/* Set TX pin to output high, enable RX pull-up */
void SoftUART_Init(void)
{
/* Set TX pin to output high, enable RX pull-up */
@@
-81,8
+81,10
@@
ISR(INT0_vect, ISR_BLOCK)
/* Reset the number of reception bits remaining counter */
RX_BitsRemaining = 8;
/* Reset the number of reception bits remaining counter */
RX_BitsRemaining = 8;
- /* Reset the bit reception timer */
- TCNT1 = 0;
+ /* Reset the bit reception timer to -(1/2) of the total bit time, so that the first data bit is
+ * sampled mid way through the total bit time, making reception more robust.
+ */
+ TCNT1 = -(OCR1A >> 1);
/* Check to see that the pin is still low (prevents glitches from starting a frame reception) */
if (!(SRXPIN & (1 << SRX)))
/* Check to see that the pin is still low (prevents glitches from starting a frame reception) */
if (!(SRXPIN & (1 << SRX)))