From fd22b16e395a182dbbc96c6b1e49b14ac49e346e Mon Sep 17 00:00:00 2001 From: James Snyder Date: Thu, 23 Apr 2015 19:32:54 -0500 Subject: [PATCH] attempt to reduce overhead of pio_op function on stm32f4 --- src/platform/stm32f4/platform.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/platform/stm32f4/platform.c b/src/platform/stm32f4/platform.c index 5e0e9f97..6e6f9296 100644 --- a/src/platform/stm32f4/platform.c +++ b/src/platform/stm32f4/platform.c @@ -263,9 +263,6 @@ pio_type platform_pio_op( unsigned port, pio_type pinmask, int op ) GPIO_InitTypeDef GPIO_InitStructure; GPIO_TypeDef * base = pio_port[ port ]; - - GPIO_StructInit(&GPIO_InitStructure); - switch( op ) { case PLATFORM_IO_PORT_SET_VALUE: @@ -283,6 +280,7 @@ pio_type platform_pio_op( unsigned port, pio_type pinmask, int op ) case PLATFORM_IO_PORT_DIR_INPUT: pinmask = GPIO_Pin_All; case PLATFORM_IO_PIN_DIR_INPUT: + GPIO_StructInit(&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = pinmask; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN; @@ -292,6 +290,7 @@ pio_type platform_pio_op( unsigned port, pio_type pinmask, int op ) case PLATFORM_IO_PORT_DIR_OUTPUT: pinmask = GPIO_Pin_All; case PLATFORM_IO_PIN_DIR_OUTPUT: + GPIO_StructInit(&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = pinmask; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; @@ -308,6 +307,7 @@ pio_type platform_pio_op( unsigned port, pio_type pinmask, int op ) break; case PLATFORM_IO_PIN_PULLUP: + GPIO_StructInit(&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = pinmask; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; @@ -315,6 +315,7 @@ pio_type platform_pio_op( unsigned port, pio_type pinmask, int op ) break; case PLATFORM_IO_PIN_PULLDOWN: + GPIO_StructInit(&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = pinmask; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_DOWN; @@ -322,6 +323,7 @@ pio_type platform_pio_op( unsigned port, pio_type pinmask, int op ) break; case PLATFORM_IO_PIN_NOPULL: + GPIO_StructInit(&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = pinmask; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;