added prescaler for 16 bit pwm in LPC1347 target

Fork of mbed-dev by mbed official

Committer:
mbed_official
Date:
Tue Apr 05 18:15:12 2016 +0100
Revision:
107:414e9c822e99
Synchronized with git revision dd3c5f7fa8473776950ec6e15c0e4adedb21cf2f

Full URL: https://github.com/mbedmicro/mbed/commit/dd3c5f7fa8473776950ec6e15c0e4adedb21cf2f/

* * Base Commit for SAMG55J19. No errors and no implementations.

* * Added gpio files.

* * Added pinmap files.

* * Base commit for usticker implementation.

* * Added gcc_arm export functionality

* * added files for usticker.
* added template file for samd55j19

* * GPIO IRQ base commit.

* * updated with changes in gpio irq driver.

* * Reverted back unexpected commit in SAM0 gpio driver.

* * updated gpio_irq driver.

* * correction in gpio and gpio_irq drivers.
* added support for some test for gpio.

* * base commit for peripheralpins for usart.
* update in serial apis.

* * updated serial apis.

* * updated serial apis and test.

* * update serial apis for asynch apis.

* * updated peripheral pins for i2c and spi.
* added test support for serial flow control

* * Base commit for low power ticker implementation.

* * base commit for port apis.
* update in lp ticker apis.

* * Added test support for port.

* * base commit for sleep apis.

* * Base commit for spi.

* * updated with corrections in gpio irq.
* usticker file updated with latest source.

* * updated with corrections for unexpected board reset.
* updated gpio irq apis and added test for the same.

* * updated sleep api for deepsleep.

* * updated serial apis.

* Added uc_ticker and SPI api implementations

* Removed unused SPI pin map

* Updated review feedback

* * implemented lpticker with TC module.
* updated files for KnR Coding Statndard.
* updated serial and usticker apis.

* * Base commit for AnalogueIn apis.

* * RTC apis base commit without implementation.

* * Updated with corrections in lpticker implementations.

* * Added implementation for rtc apis.

* * updated with implementations for pwm.
* changed usticker from TC0 to TC1.

* Added I2C support

* * removed setvector usage from usticker and lpticker implementations
* added tests for SAMG55J19

* * Removed unwanted .o and .d files.
* Updated I2C files for KnR Coding Standards.
* Update for reducing compiler warnings in peripheralpins,c
* Updated with PWM free implementation.

* * Removed unwanted headers file inclusion.
* Compiler warning corrections in serial_api.c

* * Updated ADC with 16 bit mode initialization and code refinements.
* Updated PWM with code refinements.

* Updated I2C review feedback and fixed style

* Updated target name for SAMG55

* * Added Test Support for I2C with AT30TSE75X and Added Support for SAMG55J19 in atmelstudio project exporter

* * Added Test Support for I2C with AT30TSE75X and Added Support for SAMG55J19 in atmelstudio project exporter

* Used NVIC_SetVector for interrupt callback

* Removed Target macro define in test

* Updated test cases to have SAMG55 support

* * Updated with corrections in Serial and SPI asynchronous implementations.
* Updated deepsleep api implementation
* Merged LP_Ticker with latest code from mbed 3.0 repository.

* * updated with corrections in I2C Asynch implementation.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_official 107:414e9c822e99 1 /* mbed Microcontroller Library
mbed_official 107:414e9c822e99 2 * Copyright (c) 2006-2015 ARM Limited
mbed_official 107:414e9c822e99 3 *
mbed_official 107:414e9c822e99 4 * Licensed under the Apache License, Version 2.0 (the "License");
mbed_official 107:414e9c822e99 5 * you may not use this file except in compliance with the License.
mbed_official 107:414e9c822e99 6 * You may obtain a copy of the License at
mbed_official 107:414e9c822e99 7 *
mbed_official 107:414e9c822e99 8 * http://www.apache.org/licenses/LICENSE-2.0
mbed_official 107:414e9c822e99 9 *
mbed_official 107:414e9c822e99 10 * Unless required by applicable law or agreed to in writing, software
mbed_official 107:414e9c822e99 11 * distributed under the License is distributed on an "AS IS" BASIS,
mbed_official 107:414e9c822e99 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
mbed_official 107:414e9c822e99 13 * See the License for the specific language governing permissions and
mbed_official 107:414e9c822e99 14 * limitations under the License.
mbed_official 107:414e9c822e99 15 */
mbed_official 107:414e9c822e99 16 #ifndef MBED_OBJECTS_H
mbed_official 107:414e9c822e99 17 #define MBED_OBJECTS_H
mbed_official 107:414e9c822e99 18
mbed_official 107:414e9c822e99 19 #include "cmsis.h"
mbed_official 107:414e9c822e99 20 #include "PortNames.h"
mbed_official 107:414e9c822e99 21 #include "PeripheralNames.h"
mbed_official 107:414e9c822e99 22 #include "gpio_object.h"
mbed_official 107:414e9c822e99 23 #include "serial_platform.h"
mbed_official 107:414e9c822e99 24 #include "adc2.h"
mbed_official 107:414e9c822e99 25
mbed_official 107:414e9c822e99 26 #ifdef __cplusplus
mbed_official 107:414e9c822e99 27 extern "C" {
mbed_official 107:414e9c822e99 28 #endif
mbed_official 107:414e9c822e99 29
mbed_official 107:414e9c822e99 30 struct waveconfig_t {
mbed_official 107:414e9c822e99 31 /** Internal clock signals selection. */
mbed_official 107:414e9c822e99 32 uint32_t ul_intclock;
mbed_official 107:414e9c822e99 33 /** Waveform frequency (in Hz). */
mbed_official 107:414e9c822e99 34 uint16_t us_frequency;
mbed_official 107:414e9c822e99 35 /** Duty cycle in percent (positive).*/
mbed_official 107:414e9c822e99 36 uint16_t us_dutycycle;
mbed_official 107:414e9c822e99 37 };
mbed_official 107:414e9c822e99 38
mbed_official 107:414e9c822e99 39 struct gpio_irq_s {
mbed_official 107:414e9c822e99 40 uint32_t pin;
mbed_official 107:414e9c822e99 41 uint32_t irqmask;
mbed_official 107:414e9c822e99 42 };
mbed_official 107:414e9c822e99 43
mbed_official 107:414e9c822e99 44 struct port_s {
mbed_official 107:414e9c822e99 45 PortName port;
mbed_official 107:414e9c822e99 46 uint32_t mask;
mbed_official 107:414e9c822e99 47 uint8_t mode;
mbed_official 107:414e9c822e99 48 uint8_t direction;
mbed_official 107:414e9c822e99 49 };
mbed_official 107:414e9c822e99 50
mbed_official 107:414e9c822e99 51 struct serial_s {
mbed_official 107:414e9c822e99 52 UARTName uart;
mbed_official 107:414e9c822e99 53 usart_serial_options_t uart_serial_options;
mbed_official 107:414e9c822e99 54 #if DEVICE_SERIAL_ASYNCH
mbed_official 107:414e9c822e99 55 uint8_t actrec;
mbed_official 107:414e9c822e99 56 uint8_t acttra;
mbed_official 107:414e9c822e99 57 uint32_t events;
mbed_official 107:414e9c822e99 58 #endif
mbed_official 107:414e9c822e99 59 };
mbed_official 107:414e9c822e99 60
mbed_official 107:414e9c822e99 61 struct analogin_s {
mbed_official 107:414e9c822e99 62 enum adc_channel_num channel;
mbed_official 107:414e9c822e99 63 };
mbed_official 107:414e9c822e99 64
mbed_official 107:414e9c822e99 65 struct pwmout_s {
mbed_official 107:414e9c822e99 66 uint32_t channel;
mbed_official 107:414e9c822e99 67 uint32_t ioline;
mbed_official 107:414e9c822e99 68 uint32_t pin;
mbed_official 107:414e9c822e99 69 uint32_t prescalarindex;
mbed_official 107:414e9c822e99 70 struct waveconfig_t waveconfig;
mbed_official 107:414e9c822e99 71 };
mbed_official 107:414e9c822e99 72
mbed_official 107:414e9c822e99 73 struct i2c_s {
mbed_official 107:414e9c822e99 74 Twi * i2c_base;
mbed_official 107:414e9c822e99 75 Flexcom * flexcom;
mbed_official 107:414e9c822e99 76 uint8_t is_slave;
mbed_official 107:414e9c822e99 77 uint8_t module_number;
mbed_official 107:414e9c822e99 78 uint32_t speed;
mbed_official 107:414e9c822e99 79 uint32_t master_clk;
mbed_official 107:414e9c822e99 80 uint32_t address;
mbed_official 107:414e9c822e99 81 #if DEVICE_I2C_ASYNCH
mbed_official 107:414e9c822e99 82 Pdc * pdc;
mbed_official 107:414e9c822e99 83 uint8_t dma_usage;
mbed_official 107:414e9c822e99 84 IRQn_Type irq_type;
mbed_official 107:414e9c822e99 85 uint32_t event;
mbed_official 107:414e9c822e99 86 uint32_t stop;
mbed_official 107:414e9c822e99 87 #endif
mbed_official 107:414e9c822e99 88 };
mbed_official 107:414e9c822e99 89 struct spi_s {
mbed_official 107:414e9c822e99 90 Spi * spi_base;
mbed_official 107:414e9c822e99 91 Flexcom * flexcom;
mbed_official 107:414e9c822e99 92 uint8_t cs;
mbed_official 107:414e9c822e99 93 uint8_t polarity;
mbed_official 107:414e9c822e99 94 uint8_t phase;
mbed_official 107:414e9c822e99 95 uint32_t transferrate;
mbed_official 107:414e9c822e99 96 uint8_t is_slave;
mbed_official 107:414e9c822e99 97 uint8_t module_number;
mbed_official 107:414e9c822e99 98 #if DEVICE_SPI_ASYNCH
mbed_official 107:414e9c822e99 99 Pdc * pdc;
mbed_official 107:414e9c822e99 100 uint8_t dma_usage;
mbed_official 107:414e9c822e99 101 IRQn_Type irq_type;
mbed_official 107:414e9c822e99 102 uint32_t event;
mbed_official 107:414e9c822e99 103 #endif
mbed_official 107:414e9c822e99 104 };
mbed_official 107:414e9c822e99 105
mbed_official 107:414e9c822e99 106 #ifdef __cplusplus
mbed_official 107:414e9c822e99 107 }
mbed_official 107:414e9c822e99 108 #endif
mbed_official 107:414e9c822e99 109
mbed_official 107:414e9c822e99 110 #endif