Loading...
/* * 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); |