The official mbed C/C SDK provides the software platform and libraries to build your applications.

Dependents:   SeeedTouchLCD

Fork of mbed by mbed official

(01.May.2014) started sales! http://www.switch-science.com/catalog/1717/

(13.March.2014) updated to 0.5.0

This is a pin conversion PCB from mbed 1768/11U24 to arduino UNO.

  • So if you have both mbed and arduino shields, I guess you would be happy with such a conversion board :)

Photos

  • Board photo vvv /media/uploads/k4zuki/mbedshield050.brd.png
  • Schematic photo vvv /media/uploads/k4zuki/mbedshield050.sch.png
  • Functionality photo vvv /media/uploads/k4zuki/mbedshieldfunc.jpg

Latest eagle files

PCB >> /media/uploads/k4zuki/mbedshield050.brd
SCH >> /media/uploads/k4zuki/mbedshield050.sch

BIG changes from previous version

  1. Ethernet RJ45 connector is removed.
    1. http://mbed.org/components/Seeed-Ethernet-Shield-V20/ is the biggest hint to use Ethernet!
  2. Most ALL of components can be bought at Akizuki http://akizukidenshi.com/
    1. But sorry, they do not send parts to abroad
  3. Pinout is changed!
arduino0.4.00.5.0
D4p12p21
D5p11p22
MOSI_nonep11
MISO_nonep12
SCK_nonep13

This design has bug(s)

  1. I2C functional pin differs between 1768 and 11U24.

Fixed bugs here

  1. MiniUSB cable cannot be connected on mbed if you solder high-height electrolytic capacitor on C3.
    1. http://akizukidenshi.com/catalog/g/gP-05002/ is the solution to make this 100% AKIZUKI parts!
  2. the 6-pin ISP port is not inprimented in version 0.4.0
    1. it will be fixed in later version 0.4.1/0.4.2/0.5.0 This has beenfixed

I am doing some porting to use existing arduino shields but it may faster if you do it by yourself...

you can use arduino PinName "A0-A5,D0-D13" plus backside SPI port for easier porting.

To do this you have to edit PinName enum in

  • "mbed/TARGET_LPC1768/PinNames.h" or
  • "mbed/TARGET_LPC11U24/PinNames.h" as per your target mbed.

here is the actual list: This list includes define switch to switch pin assignment

part_of_PinNames.h

        USBTX = P0_2,
        USBRX = P0_3,

//from here mbeDshield mod
        D0=p27,
        D1=p28,
        D2=p14,
        D3=p13,
#ifdef MBEDSHIELD_050
        MOSI_=p11,
        MISO_=p12,
        SCK_=p13,
        D4=p21,
        D5=p22,
#else
        D4=p12,
        D5=p11,
#endif
        D6=p23,
        D7=p24,
        D8=p25,
        D9=p26,
        D10=p8,
        D11=p5,
        D12=p6,
        D13=p7,
        A0=p15,
        A1=p16,
        A2=p17,
        A3=p18,
        A4=p19,
        A5=p20,
        SDA=p9,
        SCL=p10,
//mbeDshield mod ends here
        // Not connected
        NC = (int)0xFFFFFFFF
Committer:
emilmont
Date:
Mon Feb 18 11:12:58 2013 +0000
Revision:
59:0883845fe643
Parent:
55:d722ed6a4237
Child:
65:5798e58a58b1
Add pinmap NC terminators for LPC1768 CAN.
Update the license from MIT to Apache v2.
Make the semihost code target independent using opportune defines for the UID and MAC.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
emilmont 44:24d45a770a51 1 /* mbed Microcontroller Library
emilmont 54:71b101360fb9 2 * Copyright (c) 2006-2013 ARM Limited
emilmont 44:24d45a770a51 3 *
emilmont 59:0883845fe643 4 * Licensed under the Apache License, Version 2.0 (the "License");
emilmont 59:0883845fe643 5 * you may not use this file except in compliance with the License.
emilmont 59:0883845fe643 6 * You may obtain a copy of the License at
emilmont 59:0883845fe643 7 *
emilmont 59:0883845fe643 8 * http://www.apache.org/licenses/LICENSE-2.0
emilmont 44:24d45a770a51 9 *
emilmont 59:0883845fe643 10 * Unless required by applicable law or agreed to in writing, software
emilmont 59:0883845fe643 11 * distributed under the License is distributed on an "AS IS" BASIS,
emilmont 59:0883845fe643 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
emilmont 59:0883845fe643 13 * See the License for the specific language governing permissions and
emilmont 59:0883845fe643 14 * limitations under the License.
emilmont 44:24d45a770a51 15 */
emilmont 44:24d45a770a51 16 #ifndef MBED_PORTOUT_H
emilmont 44:24d45a770a51 17 #define MBED_PORTOUT_H
emilmont 44:24d45a770a51 18
emilmont 44:24d45a770a51 19 #include "platform.h"
emilmont 44:24d45a770a51 20
emilmont 44:24d45a770a51 21 #if DEVICE_PORTOUT
emilmont 44:24d45a770a51 22
emilmont 44:24d45a770a51 23 #include "port_api.h"
emilmont 44:24d45a770a51 24
emilmont 44:24d45a770a51 25 namespace mbed {
emilmont 44:24d45a770a51 26 /** A multiple pin digital out
emilmont 44:24d45a770a51 27 *
emilmont 44:24d45a770a51 28 * Example:
emilmont 44:24d45a770a51 29 * @code
emilmont 44:24d45a770a51 30 * // Toggle all four LEDs
emilmont 55:d722ed6a4237 31 *
emilmont 44:24d45a770a51 32 * #include "mbed.h"
emilmont 44:24d45a770a51 33 *
emilmont 44:24d45a770a51 34 * // LED1 = P1.18 LED2 = P1.20 LED3 = P1.21 LED4 = P1.23
emilmont 44:24d45a770a51 35 * #define LED_MASK 0x00B40000
emilmont 44:24d45a770a51 36 *
emilmont 44:24d45a770a51 37 * PortOut ledport(Port1, LED_MASK);
emilmont 44:24d45a770a51 38 *
emilmont 44:24d45a770a51 39 * int main() {
emilmont 44:24d45a770a51 40 * while(1) {
emilmont 44:24d45a770a51 41 * ledport = LED_MASK;
emilmont 44:24d45a770a51 42 * wait(1);
emilmont 44:24d45a770a51 43 * ledport = 0;
emilmont 44:24d45a770a51 44 * wait(1);
emilmont 44:24d45a770a51 45 * }
emilmont 44:24d45a770a51 46 * }
emilmont 44:24d45a770a51 47 * @endcode
emilmont 55:d722ed6a4237 48 */
emilmont 44:24d45a770a51 49 class PortOut {
emilmont 44:24d45a770a51 50 public:
emilmont 44:24d45a770a51 51
emilmont 44:24d45a770a51 52 /** Create an PortOut, connected to the specified port
emilmont 44:24d45a770a51 53 *
emilmont 44:24d45a770a51 54 * @param port Port to connect to (Port0-Port5)
emilmont 44:24d45a770a51 55 * @param mask A bitmask to identify which bits in the port should be included (0 - ignore)
emilmont 55:d722ed6a4237 56 */
emilmont 44:24d45a770a51 57 PortOut(PortName port, int mask = 0xFFFFFFFF) {
emilmont 44:24d45a770a51 58 port_init(&_port, port, mask, PIN_OUTPUT);
emilmont 44:24d45a770a51 59 }
emilmont 55:d722ed6a4237 60
emilmont 44:24d45a770a51 61 /** Write the value to the output port
emilmont 44:24d45a770a51 62 *
emilmont 44:24d45a770a51 63 * @param value An integer specifying a bit to write for every corresponding PortOut pin
emilmont 55:d722ed6a4237 64 */
emilmont 44:24d45a770a51 65 void write(int value) {
emilmont 44:24d45a770a51 66 port_write(&_port, value);
emilmont 44:24d45a770a51 67 }
emilmont 55:d722ed6a4237 68
emilmont 44:24d45a770a51 69 /** Read the value currently output on the port
emilmont 44:24d45a770a51 70 *
emilmont 44:24d45a770a51 71 * @returns
emilmont 44:24d45a770a51 72 * An integer with each bit corresponding to associated PortOut pin setting
emilmont 44:24d45a770a51 73 */
emilmont 44:24d45a770a51 74 int read() {
emilmont 44:24d45a770a51 75 return port_read(&_port);
emilmont 44:24d45a770a51 76 }
emilmont 44:24d45a770a51 77
emilmont 44:24d45a770a51 78 /** A shorthand for write()
emilmont 55:d722ed6a4237 79 */
emilmont 55:d722ed6a4237 80 PortOut& operator= (int value) {
emilmont 44:24d45a770a51 81 write(value);
emilmont 44:24d45a770a51 82 return *this;
emilmont 44:24d45a770a51 83 }
emilmont 55:d722ed6a4237 84
emilmont 55:d722ed6a4237 85 PortOut& operator= (PortOut& rhs) {
emilmont 44:24d45a770a51 86 write(rhs.read());
emilmont 44:24d45a770a51 87 return *this;
emilmont 44:24d45a770a51 88 }
emilmont 55:d722ed6a4237 89
emilmont 44:24d45a770a51 90 /** A shorthand for read()
emilmont 44:24d45a770a51 91 */
emilmont 55:d722ed6a4237 92 operator int() {
emilmont 44:24d45a770a51 93 return read();
emilmont 44:24d45a770a51 94 }
emilmont 44:24d45a770a51 95
emilmont 44:24d45a770a51 96 private:
emilmont 44:24d45a770a51 97 port_t _port;
emilmont 44:24d45a770a51 98 };
emilmont 44:24d45a770a51 99
emilmont 44:24d45a770a51 100 } // namespace mbed
emilmont 44:24d45a770a51 101
emilmont 44:24d45a770a51 102 #endif
emilmont 44:24d45a770a51 103
emilmont 44:24d45a770a51 104 #endif