mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-04 11:43:54 +08:00
50 lines
1.9 KiB
C
50 lines
1.9 KiB
C
|
/*
|
||
|
* Copyright (C) 2008 Google, Inc.
|
||
|
* Author: Nick Pelly <npelly@google.com>
|
||
|
*
|
||
|
* This software is licensed under the terms of the GNU General Public
|
||
|
* License version 2, as published by the Free Software Foundation, and
|
||
|
* may be copied, distributed, and modified under those terms.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*/
|
||
|
|
||
|
#ifndef __ASM_ARCH_MSM_SERIAL_HS_H
|
||
|
#define __ASM_ARCH_MSM_SERIAL_HS_H
|
||
|
|
||
|
#include <linux/serial_core.h>
|
||
|
|
||
|
/* API to request the uart clock off or on for low power management
|
||
|
* Clients should call request_clock_off() when no uart data is expected,
|
||
|
* and must call request_clock_on() before any further uart data can be
|
||
|
* received. */
|
||
|
extern void msm_hs_request_clock_off(struct uart_port *uport);
|
||
|
extern void msm_hs_request_clock_on(struct uart_port *uport);
|
||
|
|
||
|
/**
|
||
|
* struct msm_serial_hs_platform_data
|
||
|
* @rx_wakeup_irq: Rx activity irq
|
||
|
* @rx_to_inject: extra character to be inserted to Rx tty on wakeup
|
||
|
* @inject_rx: 1 = insert rx_to_inject. 0 = do not insert extra character
|
||
|
* @exit_lpm_cb: function called before every Tx transaction
|
||
|
*
|
||
|
* This is an optional structure required for UART Rx GPIO IRQ based
|
||
|
* wakeup from low power state. UART wakeup can be triggered by RX activity
|
||
|
* (using a wakeup GPIO on the UART RX pin). This should only be used if
|
||
|
* there is not a wakeup GPIO on the UART CTS, and the first RX byte is
|
||
|
* known (eg., with the Bluetooth Texas Instruments HCILL protocol),
|
||
|
* since the first RX byte will always be lost. RTS will be asserted even
|
||
|
* while the UART is clocked off in this mode of operation.
|
||
|
*/
|
||
|
struct msm_serial_hs_platform_data {
|
||
|
int rx_wakeup_irq;
|
||
|
unsigned char inject_rx_on_wakeup;
|
||
|
char rx_to_inject;
|
||
|
void (*exit_lpm_cb)(struct uart_port *);
|
||
|
};
|
||
|
|
||
|
#endif
|