mbed library sources change for ST sensors and ST BLE

Fork of mbed-src by mbed official

Revision:
558:0880f51c4036
Child:
567:a97fd0eca828
diff -r 42efda18ac92 -r 0880f51c4036 targets/hal/TARGET_WIZNET/TARGET_W7500x/pinmap.c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/targets/hal/TARGET_WIZNET/TARGET_W7500x/pinmap.c	Wed Jun 03 09:00:09 2015 +0100
@@ -0,0 +1,154 @@
+/* mbed Microcontroller Library 
+ *******************************************************************************
+ * Copyright (c) 2015 WIZnet Co.,Ltd. All rights reserved.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice,
+ *    this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
+ *    this list of conditions and the following disclaimer in the documentation
+ *    and/or other materials provided with the distribution.
+ * 3. Neither the name of ARM Limited nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *******************************************************************************
+ */
+ 
+#include "mbed_assert.h"
+#include "pinmap.h"
+#include "PortNames.h"
+
+
+// GPIO mode look-up table
+// It have to same with PinMode index in "PinNames.h"
+static const uint32_t gpio_pupd[4] = {
+    GPIO_NO_PUPD,           //  PullNone
+    GPIO_PuPd_DOWN,         //  PullDown
+    GPIO_PuPd_UP,           //  PullUp
+    GPIO_OD                 //  OpenDrain
+};
+
+uint32_t Get_GPIO_BaseAddress(uint32_t port_idx)
+{
+    uint32_t gpio_add = 0;
+    switch(port_idx)    {
+        case PortA:
+            gpio_add = GPIOA_BASE;
+            break;
+        case PortB:
+            gpio_add = GPIOB_BASE;
+            break;
+        case PortC:
+            gpio_add = GPIOC_BASE;
+            break;
+        case PortD:
+            gpio_add = GPIOD_BASE;
+            break;
+        default:
+            error("Pinmap error: wrong port number.");
+            break;
+    }
+    return gpio_add;
+}
+
+
+/**
+ * Configure pin (input, output, alternate function or analog) + output speed + AF
+ */
+
+void pin_function(PinName pin, int data) {
+    MBED_ASSERT(pin != (PinName)NC);
+    // Get the pin informations
+    uint32_t mode  = WIZ_PIN_MODE(data);
+    uint32_t pupd  = WIZ_PIN_PUPD(data);
+    uint32_t afnum;
+
+    if( mode == WIZ_MODE_AF )
+        afnum = WIZ_PIN_AFNUM(data);
+    else
+        afnum = WIZ_AFNUM(pin);
+
+    uint32_t port_index = WIZ_PORT(pin);
+    uint32_t pin_index  = WIZ_PIN(pin);
+
+
+    uint32_t gpio_add = Get_GPIO_BaseAddress(port_index);
+    GPIO_TypeDef *gpio = (GPIO_TypeDef *)gpio_add;
+
+    // Configure Alternate Function
+    // Warning: Must be done before the GPIO is initialized
+    switch (afnum) {
+        case 0:
+            HAL_PAD_AFConfig(port_index,(uint32_t)(1 << pin_index),Px_AFSR_AF0);
+            break;
+        case 1:
+            HAL_PAD_AFConfig(port_index,(uint32_t)(1 << pin_index),Px_AFSR_AF1);
+            break;
+        case 2:
+            HAL_PAD_AFConfig(port_index,(uint32_t)(1 << pin_index),Px_AFSR_AF2);
+            break;
+        case 3:
+            HAL_PAD_AFConfig(port_index,(uint32_t)(1 << pin_index),Px_AFSR_AF3);
+            break;
+        default:
+            break;
+    }
+
+    if(mode == WIZ_MODE_AF)
+        return;
+
+    // Configure GPIO
+    GPIO_InitTypeDef GPIO_InitStructure;
+    GPIO_InitStructure.GPIO_Pin       = (uint32_t)(1 << pin_index);
+    GPIO_InitStructure.GPIO_Mode      = mode;
+    GPIO_InitStructure.GPIO_Pad       = gpio_pupd[pupd];
+    HAL_GPIO_Init(gpio, &GPIO_InitStructure);
+}
+
+/**
+ * Configure pin pull-up/pull-down
+ */
+void pin_mode(PinName pin, PinMode pupd)
+{
+    MBED_ASSERT(pin != (PinName)NC);
+
+    P_Port_Def *px_pcr;
+
+    uint32_t port_index = WIZ_PORT(pin);
+
+    switch(port_index)    {
+        case PortA:
+            px_pcr = PA_PCR;
+            break;
+        case PortB:
+            px_pcr = PB_PCR;
+            break;
+        case PortC:
+            px_pcr = PC_PCR;
+            break;
+        case PortD:
+            px_pcr = (P_Port_Def*)PD_PCR;
+            break;
+        default:
+            error("Pinmap error: wrong port number.");
+            return;
+    }
+
+    px_pcr->Port[port_index] &= ~(Px_PCR_PUPD_DOWN|Px_PCR_PUPD_UP|Px_PCR_DS_HIGH| \
+                                  Px_PCR_OD | Px_PCR_IE | Px_PCR_CS_SUMMIT);
+    px_pcr->Port[port_index] |= gpio_pupd[pupd];
+}