#-1# Copyright 2016 Michal Meloun <[email protected]>2# All rights reserved.3#4# Redistribution and use in source and binary forms, with or without5# modification, are permitted provided that the following conditions6# are met:7# 1. Redistributions of source code must retain the above copyright8# notice, this list of conditions and the following disclaimer.9# 2. Redistributions in binary form must reproduce the above copyright10# notice, this list of conditions and the following disclaimer in the11# documentation and/or other materials provided with the distribution.12#13# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND14# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE15# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE16# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE17# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL18# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS19# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)20# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT21# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY22# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF23# SUCH DAMAGE.24#25#2627INTERFACE clknode;2829HEADER {30struct clknode;31}3233#34# Initialize clock node, get shanpshot of cached values35#36METHOD int init {37struct clknode *clk;38device_t dev;39};4041#42# Recalculate frequency43# req - in/out recalulated frequency44#45METHOD int recalc_freq {46struct clknode *clk;47uint64_t *freq;48};4950#51# Set frequency52# fin - parent (input)frequency.53# fout - requested output freqency. If clock cannot change frequency,54# then must return new requested frequency for his parent55METHOD int set_freq {56struct clknode *clk;57uint64_t fin;58uint64_t *fout;59int flags;60int *done;61};6263#64# Enable/disable clock65#66METHOD int set_gate {67struct clknode *clk;68bool enable;69};7071#72# Get gate status73# Return: ENXIO - method is not implemented74# ENOENT - HW doesn't support reading of gate enable75# 0 - success76#77METHOD int get_gate {78struct clknode *clk;79bool *enabled;80};8182#83# Set multiplexer84#85METHOD int set_mux {86struct clknode *clk;87int idx;88};899091