mirror of https://gitee.com/openkylin/linux.git
SERIAL: OMAP: Remove the slave idle handling from the driver
UART IP slave idle handling now taken care by runtime pm backend(hwmod layer) so remove the hackery from the driver. As discussed on the list, in future if dma mode needs to be brought back to this driver, UART sysc handling needs to be updated in framework such a way that no-idle/force idle profile can be supported. Given the broken dma mode for OMAP uarts, its very unlikely. Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Tested-by: Vaibhav Bedia <vaibhav.bedia@ti.com> Tested-by: Sourav Poddar <sourav.poddar@ti.com> Signed-off-by: Rajendra nayak <rnayak@ti.com> Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com> Reviewed-by: Kevin Hilman <khilman@linaro.org> Tested-by: Kevin Hilman <khilman@linaro.org> # OMAP4/Panda Signed-off-by: Paul Walmsley <paul@pwsan.com>
This commit is contained in:
parent
e59cd225c0
commit
7f18d05a1a
|
@ -202,26 +202,6 @@ static int serial_omap_get_context_loss_count(struct uart_omap_port *up)
|
||||||
return pdata->get_context_loss_count(up->dev);
|
return pdata->get_context_loss_count(up->dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void serial_omap_set_forceidle(struct uart_omap_port *up)
|
|
||||||
{
|
|
||||||
struct omap_uart_port_info *pdata = up->dev->platform_data;
|
|
||||||
|
|
||||||
if (!pdata || !pdata->set_forceidle)
|
|
||||||
return;
|
|
||||||
|
|
||||||
pdata->set_forceidle(up->dev);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void serial_omap_set_noidle(struct uart_omap_port *up)
|
|
||||||
{
|
|
||||||
struct omap_uart_port_info *pdata = up->dev->platform_data;
|
|
||||||
|
|
||||||
if (!pdata || !pdata->set_noidle)
|
|
||||||
return;
|
|
||||||
|
|
||||||
pdata->set_noidle(up->dev);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void serial_omap_enable_wakeup(struct uart_omap_port *up, bool enable)
|
static void serial_omap_enable_wakeup(struct uart_omap_port *up, bool enable)
|
||||||
{
|
{
|
||||||
struct omap_uart_port_info *pdata = up->dev->platform_data;
|
struct omap_uart_port_info *pdata = up->dev->platform_data;
|
||||||
|
@ -298,8 +278,6 @@ static void serial_omap_stop_tx(struct uart_port *port)
|
||||||
serial_out(up, UART_IER, up->ier);
|
serial_out(up, UART_IER, up->ier);
|
||||||
}
|
}
|
||||||
|
|
||||||
serial_omap_set_forceidle(up);
|
|
||||||
|
|
||||||
pm_runtime_mark_last_busy(up->dev);
|
pm_runtime_mark_last_busy(up->dev);
|
||||||
pm_runtime_put_autosuspend(up->dev);
|
pm_runtime_put_autosuspend(up->dev);
|
||||||
}
|
}
|
||||||
|
@ -364,7 +342,6 @@ static void serial_omap_start_tx(struct uart_port *port)
|
||||||
|
|
||||||
pm_runtime_get_sync(up->dev);
|
pm_runtime_get_sync(up->dev);
|
||||||
serial_omap_enable_ier_thri(up);
|
serial_omap_enable_ier_thri(up);
|
||||||
serial_omap_set_noidle(up);
|
|
||||||
pm_runtime_mark_last_busy(up->dev);
|
pm_runtime_mark_last_busy(up->dev);
|
||||||
pm_runtime_put_autosuspend(up->dev);
|
pm_runtime_put_autosuspend(up->dev);
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,8 +43,6 @@ struct omap_uart_port_info {
|
||||||
int DTR_present;
|
int DTR_present;
|
||||||
|
|
||||||
int (*get_context_loss_count)(struct device *);
|
int (*get_context_loss_count)(struct device *);
|
||||||
void (*set_forceidle)(struct device *);
|
|
||||||
void (*set_noidle)(struct device *);
|
|
||||||
void (*enable_wakeup)(struct device *, bool);
|
void (*enable_wakeup)(struct device *, bool);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue