blob: 5f283dab3fa3cc4cc965531db0695f4f000e7d2f [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);
38int pil_q6v5_init_image(struct pil_desc *pil, const u8 *metadata,
39 size_t size);
40void pil_q6v5_shutdown(struct pil_desc *pil);
41int pil_q6v5_reset(struct pil_desc *pil);
Matt Wagantalld41ce772012-05-10 23:16:41 -070042int pil_q6v5_enable_clks(struct pil_desc *pil);
43void pil_q6v5_disable_clks(struct pil_desc *pil);
Matt Wagantallb3fe8992011-12-07 19:26:55 -080044struct pil_desc *pil_q6v5_init(struct platform_device *pdev);
45
46#endif