blob: b65b12d1cc66e9eade922215adfa70ae8cae1bf4 [file] [log] [blame]
#!/bin/sh -e
# Read and control VCS rails by sending the UCD power sequencer I2C commands.
# This script assumes that the UCD is controlling VCS rails as GPIOs 5 and 6.
# Also assumes that those GPIOs are already enabled.
ucd_bus="0"
ucd_addr="0x64"
ucd_path="/sys/bus/i2c/drivers/ucd9000"
ucd_driver="${ucd_bus}-00${ucd_addr#0x}"
ucd_retries="5"
retry()
{
local i=0
until [ $i -ge $ucd_retries ]; do
i=$((i+1))
retry_output=`$@` && break
done
local ret=$?
if [ $i -eq $ucd_retries ]; then exit $ret; fi
}
# Usage: ucd_get address
# Result stored in $ucd_reg
ucd_get()
{
retry i2cget -y $ucd_bus $ucd_addr $1 b
ucd_reg=$retry_output
}
# Usage: ucd_get address value
ucd_set()
{
retry i2cset -y $ucd_bus $ucd_addr $1 $2 b
}
unbind_ucd()
{
if [ -e $ucd_path/$ucd_driver ]; then
echo -e "\tUnbinding UCD driver $ucd_driver"
echo $ucd_driver > $ucd_path/unbind
else
echo -e "\tWarning: $ucd_path/$ucd_driver doesn't exist"
fi
}
rebind_ucd()
{
if [ -e $ucd_path ]; then
echo -e "\tBinding UCD driver $ucd_driver"
local i=0
until [ -d $ucd_path/$ucd_driver ] || [ $i -ge $ucd_retries ]; do
i=$((i+1))
echo $ucd_driver > $ucd_path/bind || ret=$?
done
if [ ! -d $ucd_path/$ucd_driver ]; then exit $ret; fi
fi
}
vcs_set_gpios()
{
unbind_ucd
echo -e "\tSetting UCD GPIO 5 to $1"
ucd_set 0xFA 5
ucd_set 0xFB $1
ucd_set 0xFB $1
echo -e "\tSetting UCD GPIO 6 to $1"
ucd_set 0xFA 6
ucd_set 0xFB $1
ucd_set 0xFB $1
rebind_ucd
}
vcs_get()
{
echo Reading VCS settings
unbind_ucd
ucd_set 0xFA 5
ucd_get 0xFB
local val=`echo $ucd_reg | grep -i -c 0x0f`
echo -e "\tUCD GPIO 5 state=$val"
ucd_set 0xFA 6
ucd_get 0xFB
local val=`echo $ucd_reg | grep -i -c 0x0f`
echo -e "\tUCD GPIO 6 state=$val"
rebind_ucd
}
if [ "$1" == "on" ]; then
echo Turning on VCS
vcs_set_gpios 0x7
elif [ "$1" == "off" ]; then
echo Turning off VCS
vcs_set_gpios 0x3
else
vcs_get
echo "$0 <on|off>" to set state
fi