diff options
author | Fabio Utzig <utzig@utzig.org> | 2015-06-04 12:25:39 +0000 |
---|---|---|
committer | Fabio Utzig <utzig@utzig.org> | 2015-06-04 12:25:39 +0000 |
commit | 0e2b620290bcf45094f086e9d7a744a1c312b42b (patch) | |
tree | 7cfe81d0a3f60690a554297942d858e9970fb179 /os/nil | |
parent | 6f6da8a73e877306e1fd96bfb5015de9849c575b (diff) | |
download | ChibiOS-0e2b620290bcf45094f086e9d7a744a1c312b42b.tar.gz ChibiOS-0e2b620290bcf45094f086e9d7a744a1c312b42b.tar.bz2 ChibiOS-0e2b620290bcf45094f086e9d7a744a1c312b42b.zip |
[AVR] Add support for models with 3-byte sized PC
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@8009 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/nil')
-rw-r--r-- | os/nil/ports/AVR/nilcore.h | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/os/nil/ports/AVR/nilcore.h b/os/nil/ports/AVR/nilcore.h index 9c915f303..c8636ebb0 100644 --- a/os/nil/ports/AVR/nilcore.h +++ b/os/nil/ports/AVR/nilcore.h @@ -161,6 +161,9 @@ struct port_intctx { uint8_t r4;
uint8_t r3;
uint8_t r2;
+#ifdef __AVR_3_BYTE_PC__
+ uint8_t pcx;
+#endif
uint8_t pcl;
uint8_t pch;
};
@@ -176,6 +179,7 @@ struct port_intctx { * @details This code usually setup the context switching frame represented
* by an @p port_intctx structure.
*/
+#ifdef __AVR_3_BYTE_PC__
#define PORT_SETUP_CONTEXT(tp, wend, pf, arg) { \
(tp)->ctxp = (struct port_intctx*)(((uint8_t *)(wend)) - \
sizeof(struct port_intctx)); \
@@ -183,10 +187,22 @@ struct port_intctx { (tp)->ctxp->r3 = (int)pf >> 8; \
(tp)->ctxp->r4 = (int)arg; \
(tp)->ctxp->r5 = (int)arg >> 8; \
+ (tp)->ctxp->pcx = 0; \
(tp)->ctxp->pcl = (int)_port_thread_start >> 8; \
(tp)->ctxp->pch = (int)_port_thread_start; \
}
-
+#else /* __AVR_3_BYTE_PC__ */
+#define PORT_SETUP_CONTEXT(tp, wend, pf, arg) { \
+ (tp)->ctxp = (struct port_intctx*)(((uint8_t *)(wend)) - \
+ sizeof(struct port_intctx)); \
+ (tp)->ctxp->r2 = (int)pf; \
+ (tp)->ctxp->r3 = (int)pf >> 8; \
+ (tp)->ctxp->r4 = (int)arg; \
+ (tp)->ctxp->r5 = (int)arg >> 8; \
+ (tp)->ctxp->pcl = (int)_port_thread_start >> 8; \
+ (tp)->ctxp->pch = (int)_port_thread_start; \
+}
+#endif /* __AVR_3_BYTE_PC__ */
/**
* @brief Computes the thread working area global size.
* @note There is no need to perform alignments in this macro.
|