2012-09-17 07:53:00 +00:00
|
|
|
/*
|
2012-11-28 10:12:28 +00:00
|
|
|
* Licensed under ST Liberty SW License Agreement V2, (the "License");
|
|
|
|
* You may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at:
|
|
|
|
*
|
|
|
|
* http://www.st.com/software_license_agreement_liberty_v2
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2012-09-17 07:53:00 +00:00
|
|
|
|
|
|
|
#include "ch.h"
|
|
|
|
#include "hal.h"
|
|
|
|
|
2012-09-21 14:55:10 +00:00
|
|
|
#if HAL_USE_PAL || defined(__DOXYGEN__)
|
2012-12-12 11:29:01 +00:00
|
|
|
/* Initial setup of all defined pads, the list is terminated by a {0, 0, 0}.*/
|
2012-11-19 08:42:07 +00:00
|
|
|
static const spc_siu_init_t spc_siu_init[] = {
|
2012-12-12 11:29:01 +00:00
|
|
|
{PCR(PORT_B, PB_LIN0_TDX), PAL_HIGH, PAL_MODE_OUTPUT_ALTERNATE(1)},
|
|
|
|
{PCR(PORT_B, PB_LIN0_RDX), PAL_HIGH, PAL_MODE_INPUT},
|
|
|
|
{PCR(PORT_D, PD_BUTTON1), PAL_LOW, PAL_MODE_INPUT},
|
|
|
|
{PCR(PORT_D, PD_BUTTON2), PAL_LOW, PAL_MODE_INPUT},
|
|
|
|
{PCR(PORT_D, PD_BUTTON3), PAL_LOW, PAL_MODE_INPUT},
|
|
|
|
{PCR(PORT_D, PD_BUTTON4), PAL_LOW, PAL_MODE_INPUT},
|
|
|
|
{PCR(PORT_D, PD_LED1), PAL_HIGH, PAL_MODE_OUTPUT_PUSHPULL},
|
|
|
|
{PCR(PORT_D, PD_LED2), PAL_HIGH, PAL_MODE_OUTPUT_PUSHPULL},
|
|
|
|
{PCR(PORT_D, PD_LED3), PAL_HIGH, PAL_MODE_OUTPUT_PUSHPULL},
|
|
|
|
{PCR(PORT_D, PD_LED4), PAL_HIGH, PAL_MODE_OUTPUT_PUSHPULL},
|
2012-09-26 15:31:12 +00:00
|
|
|
{0, 0, 0}
|
2012-09-21 14:55:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Initialization array for the PSMI registers.*/
|
2012-12-12 09:41:58 +00:00
|
|
|
static const uint8_t spc_padsels_init[SPC5_SIUL_NUM_PADSELS] = {
|
2012-09-21 14:55:10 +00:00
|
|
|
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
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PAL setup.
|
|
|
|
*/
|
2012-11-20 15:53:33 +00:00
|
|
|
const PALConfig pal_default_config = {
|
2012-09-26 15:31:12 +00:00
|
|
|
PAL_MODE_UNCONNECTED, /* Default mode for all undefined pads. */
|
2012-11-19 08:42:07 +00:00
|
|
|
spc_siu_init,
|
|
|
|
spc_padsels_init
|
2012-09-21 14:55:10 +00:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2012-09-17 07:53:00 +00:00
|
|
|
/*
|
|
|
|
* Early initialization code.
|
|
|
|
* This initialization must be performed just after stack setup and before
|
|
|
|
* any other initialization.
|
|
|
|
*/
|
|
|
|
void __early_init(void) {
|
|
|
|
|
2012-11-19 11:50:14 +00:00
|
|
|
spc_clock_init();
|
2012-11-19 12:12:16 +00:00
|
|
|
|
|
|
|
/* SWT disabled.*/
|
|
|
|
SWT.SR.R = 0xC520;
|
|
|
|
SWT.SR.R = 0xD928;
|
|
|
|
SWT.CR.R = 0xFF00000A;
|
2012-09-17 07:53:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Board-specific initialization code.
|
|
|
|
*/
|
|
|
|
void boardInit(void) {
|
|
|
|
|
|
|
|
}
|