ipq8064: prepare include files before adding UART driver
These patch modifies .h files to match the coreboot API. A few more significant changes are: - UART specific fields removed from common board structure in cdp.h. These fields are set at compile time in u-boot (where this structure comes from), they will be set in a different structure in the UART driver in an upcoming patch. - an inline wrapper is added in gpio.h to provide GPIO API the UART driver expects. - the ipq_configure_gpio() is passed the descriptor placed in ro data. BUG=chrome-os-partner:27784 TEST=none Change-Id: Id49507fb0c72ef993a89b538cd417b6c86ae3786 Signed-off-by: Vadim Bendebury <vbendeb@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/196661 Reviewed-by: Stefan Reinauer <reinauer@chromium.org>
This commit is contained in:
parent
94a36ad79a
commit
ea400f1b72
5 changed files with 12 additions and 14 deletions
|
|
@ -37,6 +37,7 @@ unsigned char uart_rx_byte(void);
|
|||
void uart_tx_byte(unsigned char data);
|
||||
void uart_tx_flush(void);
|
||||
void uart_init(void);
|
||||
int uart_can_rx_byte(void);
|
||||
#endif
|
||||
|
||||
#if CONFIG_HAVE_UART_MEMORY_MAPPED
|
||||
|
|
|
|||
|
|
@ -106,20 +106,12 @@ typedef struct {
|
|||
|
||||
/* Board specific parameters */
|
||||
typedef struct {
|
||||
unsigned int machid;
|
||||
unsigned int ddr_size;
|
||||
unsigned int uart_gsbi;
|
||||
unsigned int uart_gsbi_base;
|
||||
unsigned int uart_dm_base;
|
||||
unsigned int clk_dummy;
|
||||
#if 0
|
||||
uart_clk_mnd_t mnd_value;
|
||||
unsigned int gmac_gpio_count;
|
||||
gpio_func_data_t *gmac_gpio;
|
||||
ipq_gmac_board_cfg_t gmac_cfg[IPQ_GMAC_NMACS];
|
||||
flash_desc flashdesc;
|
||||
spinorflash_params_t flash_param;
|
||||
gpio_func_data_t dbg_uart_gpio[NO_OF_DBG_UART_GPIOS];
|
||||
#endif
|
||||
} __attribute__ ((__packed__)) board_ipq806x_params_t;
|
||||
|
||||
|
|
@ -141,5 +133,5 @@ static inline int gmac_cfg_is_valid(ipq_gmac_board_cfg_t *cfg)
|
|||
#endif
|
||||
|
||||
unsigned int get_board_index(unsigned machid);
|
||||
void ipq_configure_gpio(gpio_func_data_t *gpio, unsigned count);
|
||||
void ipq_configure_gpio(const gpio_func_data_t *gpio, unsigned count);
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -92,4 +92,12 @@ void gpio_tlmm_config_get(gpio_t gpio, unsigned int *func,
|
|||
|
||||
void gpio_io_config_set(gpio_t gpio, unsigned int out);
|
||||
void gpio_io_config_get(gpio_t gpio, unsigned int *in, unsigned int *out);
|
||||
|
||||
/* Keep this to maintain backwards compatibility with the vendor API. */
|
||||
static inline void gpio_tlmm_config(unsigned int gpio, unsigned int func,
|
||||
unsigned int dir, unsigned int pull,
|
||||
unsigned int drvstr, unsigned int enable)
|
||||
{
|
||||
gpio_tlmm_config_set(gpio, func, pull, drvstr, enable);
|
||||
}
|
||||
#endif // __SOC_QUALCOMM_IPQ806X_GPIO_H_
|
||||
|
|
|
|||
|
|
@ -19,8 +19,6 @@
|
|||
#ifndef __GSBI_H_
|
||||
#define __GSBI_H_
|
||||
|
||||
#include <asm/io.h>
|
||||
|
||||
/* GSBI Registers */
|
||||
#define GSBI_CTRL_REG(base) ((base) + 0x0)
|
||||
|
||||
|
|
|
|||
|
|
@ -32,14 +32,13 @@
|
|||
#ifndef __UART_DM_H__
|
||||
#define __UART_DM_H__
|
||||
|
||||
#include <asm/io.h>
|
||||
#include "common.h"
|
||||
#define PERIPH_BLK_BLSP 0
|
||||
|
||||
#define MSM_BOOT_UART_DM_EXTR_BITS(value, start_pos, end_pos) \
|
||||
((value << (32 - end_pos))\
|
||||
>> (32 - (end_pos - start_pos)))
|
||||
|
||||
|
||||
extern void dsb(void);
|
||||
#define PACK_CHARS_INTO_WORDS(a, cnt, word) { \
|
||||
word = 0; \
|
||||
int j; \
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue