diff options
-rw-r--r-- | boards/GENERIC_SPC560P/board.c | 6 | ||||
-rw-r--r-- | os/hal/platforms/SPC560Pxx/hal_lld.h | 2 | ||||
-rw-r--r-- | os/hal/platforms/SPC560Pxx/spc560p_registry.h | 11 | ||||
-rw-r--r-- | os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.c | 61 | ||||
-rw-r--r-- | os/hal/platforms/SPC5xx/SIUL_v1/pal_lld.h | 75 |
5 files changed, 105 insertions, 50 deletions
diff --git a/boards/GENERIC_SPC560P/board.c b/boards/GENERIC_SPC560P/board.c index b5e17a840..e6b1abf9c 100644 --- a/boards/GENERIC_SPC560P/board.c +++ b/boards/GENERIC_SPC560P/board.c @@ -23,7 +23,7 @@ #if HAL_USE_PAL || defined(__DOXYGEN__)
/* Initial setup of all defined pads, the list is terminated by a {0, 0}.*/
-static const spc560p_siul_init_t spc560p_siul_init[] = {
+static const spc560p_siu_init_t spc560p_siu_init[] = {
{PCR(PD, PD_BUTTON1), PAL_LOW, PAL_MODE_INPUT},
{PCR(PD, PD_BUTTON2), PAL_LOW, PAL_MODE_INPUT},
{PCR(PD, PD_BUTTON3), PAL_LOW, PAL_MODE_INPUT},
@@ -36,7 +36,7 @@ static const spc560p_siul_init_t spc560p_siul_init[] = { };
/* Initialization array for the PSMI registers.*/
-static const uint8_t spc560p_padsels_init[SPC5_SIUL_NUM_PADSELS] = {
+static const uint8_t spc560p_padsels_init[SPC5_SIU_NUM_PADSELS] = {
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0
@@ -48,7 +48,7 @@ static const uint8_t spc560p_padsels_init[SPC5_SIUL_NUM_PADSELS] = { const PALConfig pal_default_config =
{
PAL_MODE_UNCONNECTED, /* Default mode for all undefined pads. */
- spc560p_siul_init,
+ spc560p_siu_init,
spc560p_padsels_init
};
#endif
diff --git a/os/hal/platforms/SPC560Pxx/hal_lld.h b/os/hal/platforms/SPC560Pxx/hal_lld.h index 9af90e713..1e4cf3e2b 100644 --- a/os/hal/platforms/SPC560Pxx/hal_lld.h +++ b/os/hal/platforms/SPC560Pxx/hal_lld.h @@ -50,7 +50,7 @@ * @name Platform identification
* @{
*/
-#define PLATFORM_NAME "SPC560Pxx Chassis and Safety"
+#define PLATFORM_NAME "SPC560Pxx Chassis and Safety"
/** @} */
/**
diff --git a/os/hal/platforms/SPC560Pxx/spc560p_registry.h b/os/hal/platforms/SPC560Pxx/spc560p_registry.h index b88681419..b17b4962f 100644 --- a/os/hal/platforms/SPC560Pxx/spc560p_registry.h +++ b/os/hal/platforms/SPC560Pxx/spc560p_registry.h @@ -37,11 +37,12 @@ * @name SPC560Pxx capabilities
* @{
*/
-/* SIUL attributes.*/
-#define SPC5_HAS_SIUL TRUE
-#define SPC5_SIUL_NUM_PORTS 4
-#define SPC5_SIUL_NUM_PCRS 108
-#define SPC5_SIUL_NUM_PADSELS 36
+/* SIU/SIUL attributes.*/
+#define SPC5_HAS_SIU FALSE
+#define SPC5_SIU_SUPPORTS_PORTS TRUE
+#define SPC5_SIU_NUM_PORTS 4
+#define SPC5_SIU_NUM_PCRS 108
+#define SPC5_SIU_NUM_PADSELS 36
/** @} */
#endif /* _SPC560P_REGISTRY_H_ */
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);
|