12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- /*
- * Actions Semi Owl Smart Power System (SPS) shared helpers
- *
- * Copyright 2012 Actions Semi Inc.
- * Author: Actions Semi, Inc.
- *
- * Copyright (c) 2017 Andreas Färber
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License as published by the
- * Free Software Foundation; either version 2 of the License, or (at your
- * option) any later version.
- */
- #include <linux/delay.h>
- #include <linux/io.h>
- #define OWL_SPS_PG_CTL 0x0
- int owl_sps_set_pg(void __iomem *base, u32 pwr_mask, u32 ack_mask, bool enable)
- {
- u32 val;
- bool ack;
- int timeout;
- val = readl(base + OWL_SPS_PG_CTL);
- ack = val & ack_mask;
- if (ack == enable)
- return 0;
- if (enable)
- val |= pwr_mask;
- else
- val &= ~pwr_mask;
- writel(val, base + OWL_SPS_PG_CTL);
- for (timeout = 5000; timeout > 0; timeout -= 50) {
- val = readl(base + OWL_SPS_PG_CTL);
- if ((val & ack_mask) == (enable ? ack_mask : 0))
- break;
- udelay(50);
- }
- if (timeout <= 0)
- return -ETIMEDOUT;
- udelay(10);
- return 0;
- }
- EXPORT_SYMBOL_GPL(owl_sps_set_pg);
|