aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/platforms/SPC5xx
diff options
context:
space:
mode:
Diffstat (limited to 'os/hal/platforms/SPC5xx')
-rw-r--r--os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.c61
-rw-r--r--os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.h75
2 files changed, 95 insertions, 41 deletions
diff --git a/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.c b/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.c
index 8ab0c365c..edb4934ba 100644
--- a/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.c
+++ b/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.c
@@ -19,8 +19,8 @@
*/
/**
- * @file SPC5xx/SIUL_v1/pal_lld.c
- * @brief SPC5xx SIUL low level driver code.
+ * @file SPC5xx/SIU_v1/pal_lld.c
+ * @brief SPC5xx SIU/SIUL low level driver code.
*
* @addtogroup PAL
* @{
@@ -66,11 +66,11 @@ void _pal_lld_init(const PALConfig *config) {
unsigned i;
/* Initialize PCR registers for undefined pads.*/
- for (i = 0; i < SPC5_SIUL_NUM_PCRS; i++)
+ for (i = 0; i < SPC5_SIU_NUM_PCRS; i++)
SIU.PCR[i].R = config->default_mode;
/* Initialize PADSEL registers.*/
- for (i = 0; i < SPC5_SIUL_NUM_PADSELS; i++)
+ for (i = 0; i < SPC5_SIU_NUM_PADSELS; i++)
SIU.PSMI[i].R = config->padsels[i];
/* Initialize PCR registers for defined pads.*/
@@ -83,6 +83,48 @@ void _pal_lld_init(const PALConfig *config) {
}
/**
+ * @brief Reads a group of bits.
+ *
+ * @param[in] port port identifier
+ * @param[in] mask group mask
+ * @param[in] offset group bit offset within the port
+ * @return The group logical states.
+ *
+ * @notapi
+ */
+ioportmask_t _pal_lld_readgroup(ioportid_t port,
+ ioportmask_t mask,
+ uint_fast8_t offset) {
+
+ (void)port;
+ (void)mask;
+ (void)offset;
+ return 0;
+}
+
+/**
+ * @brief Writes a group of bits.
+ *
+ * @param[in] port port identifier
+ * @param[in] mask group mask
+ * @param[in] offset group bit offset within the port
+ * @param[in] bits bits to be written. Values exceeding the group width
+ * are masked.
+ *
+ * @notapi
+ */
+void _pal_lld_writegroup(ioportid_t port,
+ ioportmask_t mask,
+ uint_fast8_t offset,
+ ioportmask_t bits) {
+
+ (void)port;
+ (void)mask;
+ (void)offset;
+ (void)bits;
+}
+
+/**
* @brief Pads mode setup.
* @details This function programs a pads group belonging to the same port
* with the specified mode.
@@ -96,9 +138,14 @@ void _pal_lld_init(const PALConfig *config) {
void _pal_lld_setgroupmode(ioportid_t port,
ioportmask_t mask,
iomode_t mode) {
- (void)port;
- (void)mask;
- (void)mode;
+ unsigned pcr_index = (unsigned)(port * PAL_IOPORTS_WIDTH);
+ ioportmask_t m1 = 0x8000;
+ while (m1) {
+ if (mask & m1)
+ SIU.PCR[pcr_index].R = mode;
+ m1 >>= 1;
+ ++pcr_index;
+ }
}
#endif /* HAL_USE_PAL */
diff --git a/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.h b/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.h
index 2ec806b62..a8bc7b332 100644
--- a/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.h
+++ b/os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.h
@@ -19,8 +19,8 @@
*/
/**
- * @file SPC5xx/SIUL_v1//pal_lld.h
- * @brief SPC5xx SIUL low level driver header.
+ * @file SPC5xx/SIU_v1//pal_lld.h
+ * @brief SPC5xx SIU/SIUL low level driver header.
*
* @addtogroup PAL
* @{
@@ -147,7 +147,7 @@ typedef struct {
uint8_t pcr_index;
uint8_t gpdo_value;
iomode_t pcr_value;
-} spc560p_siul_init_t;
+} spc560p_siu_init_t;
/**
* @brief Generic I/O ports static initializer.
@@ -160,7 +160,7 @@ typedef struct {
*/
typedef struct {
iomode_t default_mode;
- const spc560p_siul_init_t *inits;
+ const spc560p_siu_init_t *inits;
const uint8_t *padsels;
} PALConfig;
@@ -204,76 +204,76 @@ typedef struct {
#define PAL_PORT_BIT(n) ((ioportmask_t)(0x8000U >> (n)))
/**
- * @brief Workaround read port because bad header implementation.
+ * @brief Low level PAL subsystem initialization.
*
- * @param[in] port port identifier
- * @return The port bits.
+ * @param[in] config architecture-dependent ports configuration
*
* @notapi
*/
-#define PAL_SIUL_READ_PORT(port) (((volatile uint16_t *)SIU.PGPDI)[port])
+#define pal_lld_init(config) _pal_lld_init(config)
+#if SPC5_SIU_SUPPORTS_PORTS || defined(__DOXYGEN__)
/**
- * @brief Workaround read latch because bad header implementation.
+ * @brief Reads the physical I/O port states.
*
* @param[in] port port identifier
* @return The port bits.
*
* @notapi
*/
-#define PAL_SIUL_READ_LATCH(port) (((volatile uint16_t *)SIU.PGPDO)[port])
+#define pal_lld_readport(port) (((volatile uint16_t *)SIU.PGPDI)[port])
/**
- * @brief Workaround write port because bad header implementation.
+ * @brief Reads the output latch.
+ * @details The purpose of this function is to read back the latched output
+ * value.
*
* @param[in] port port identifier
- * @param[in] bits bits to be written on the specified port
- *
- * @notapi
- */
-#define PAL_SIUL_WRITE_PORT(port, bits) \
- (((volatile uint16_t *)SIU.PGPDO)[port] = (bits))
-
-/**
- * @brief Low level PAL subsystem initialization.
- *
- * @param[in] config architecture-dependent ports configuration
+ * @return The latched logical states.
*
* @notapi
*/
-#define pal_lld_init(config) _pal_lld_init(config)
+#define pal_lld_readlatch(port) (((volatile uint16_t *)SIU.PGPDO)[port])
/**
- * @brief Reads the physical I/O port states.
+ * @brief Writes a bits mask on a I/O port.
*
* @param[in] port port identifier
- * @return The port bits.
+ * @param[in] bits bits to be written on the specified port
*
* @notapi
*/
-#define pal_lld_readport(port) PAL_SIUL_READ_PORT(port)
+#define pal_lld_writeport(port, bits) \
+ (((volatile uint16_t *)SIU.PGPDO)[port] = (bits))
/**
- * @brief Reads the output latch.
- * @details The purpose of this function is to read back the latched output
- * value.
+ * @brief Reads a group of bits.
*
* @param[in] port port identifier
- * @return The latched logical states.
+ * @param[in] mask group mask
+ * @param[in] offset group bit offset within the port
+ * @return The group logical states.
*
* @notapi
*/
-#define pal_lld_readlatch(port) PAL_SIUL_READ_LATCH(port)
+#define pal_lld_readgroup(port, mask, offset) \
+ _pal_lld_readgroup(port, mask, offset)
/**
- * @brief Writes a bits mask on a I/O port.
+ * @brief Writes a group of bits.
*
* @param[in] port port identifier
- * @param[in] bits bits to be written on the specified port
+ * @param[in] mask group mask
+ * @param[in] offset group bit offset within the port
+ * @param[in] bits bits to be written. Values exceeding the group width
+ * are masked.
*
* @notapi
*/
-#define pal_lld_writeport(port, bits) PAL_SIUL_WRITE_PORT(port, bits)
+#define pal_lld_writegroup(port, mask, offset, bits) \
+ _pal_lld_writegroup(port, mask, offset, bits)
+
+#endif /* SPC5_SIU_SUPPORTS_PORTS */
/**
* @brief Pads group mode setup.
@@ -370,6 +370,13 @@ extern const PALConfig pal_default_config;
extern "C" {
#endif
void _pal_lld_init(const PALConfig *config);
+ ioportmask_t _pal_lld_readgroup(ioportid_t port,
+ ioportmask_t mask,
+ uint_fast8_t offset);
+ void _pal_lld_writegroup(ioportid_t port,
+ ioportmask_t mask,
+ uint_fast8_t offset,
+ ioportmask_t bits);
void _pal_lld_setgroupmode(ioportid_t port,
ioportmask_t mask,
iomode_t mode);