blob: a9a8d07c2607e49b73e3e43742aadcf70794e1fc [file] [log] [blame]
Matt Wagantallb3fe8992011-12-07 19:26:55 -08001/*
2 * Copyright (c) 2012, Code Aurora Forum. All rights reserved.
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 and
6 * only version 2 as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 */
13#ifndef __MSM_PIL_Q6V5_H
14#define __MSM_PIL_Q6V5_H
15
16struct regulator;
17struct clk;
18struct pil_device;
19struct pil_desc;
20struct platform_device;
21
22struct q6v5_data {
23 void __iomem *reg_base;
Matt Wagantalld41ce772012-05-10 23:16:41 -070024 struct clk *xo;
25 struct clk *bus_clk;
26 struct clk *core_clk;
Matt Wagantallc2bbdc32012-03-21 19:44:50 -070027 void __iomem *axi_halt_base;
Matt Wagantallb3fe8992011-12-07 19:26:55 -080028 void __iomem *rmb_base;
29 unsigned long start_addr;
30 struct regulator *vreg;
Matt Wagantalld41ce772012-05-10 23:16:41 -070031 bool is_booted;
Matt Wagantallb3fe8992011-12-07 19:26:55 -080032 int self_auth;
Matt Wagantallb3fe8992011-12-07 19:26:55 -080033 struct pil_device *pil;
34};
35
36int pil_q6v5_make_proxy_votes(struct pil_desc *pil);
37void pil_q6v5_remove_proxy_votes(struct pil_desc *pil);
Matt Wagantallb7747992012-05-11 19:37:51 -070038void pil_q6v5_halt_axi_port(struct pil_desc *pil, void __iomem *halt_base);
Matt Wagantallb3fe8992011-12-07 19:26:55 -080039int pil_q6v5_init_image(struct pil_desc *pil, const u8 *metadata,
40 size_t size);
41void pil_q6v5_shutdown(struct pil_desc *pil);
42int pil_q6v5_reset(struct pil_desc *pil);
Matt Wagantalld41ce772012-05-10 23:16:41 -070043int pil_q6v5_enable_clks(struct pil_desc *pil);
44void pil_q6v5_disable_clks(struct pil_desc *pil);
Matt Wagantallb3fe8992011-12-07 19:26:55 -080045struct pil_desc *pil_q6v5_init(struct platform_device *pdev);
46
47#endif