2021-06-03 12:51:01 -05:00
|
|
|
#!/usr/bin/env python3
|
2023-08-04 14:01:49 -05:00
|
|
|
import sys
|
|
|
|
import os
|
2021-06-03 12:51:01 -05:00
|
|
|
import time
|
2023-08-04 14:01:49 -05:00
|
|
|
import syslog
|
|
|
|
import glob
|
|
|
|
import click
|
|
|
|
from platform_config import MAC_DEFAULT_PARAM
|
|
|
|
from platform_util import getSdkReg, write_sysfs, get_value, get_format_value
|
|
|
|
|
|
|
|
|
|
|
|
AVSCTROL_DEBUG_FILE = "/etc/.avscontrol_debug_flag"
|
2021-06-03 12:51:01 -05:00
|
|
|
|
2023-08-04 14:01:49 -05:00
|
|
|
AVSCTROLERROR = 1
|
|
|
|
AVSCTROLDEBUG = 2
|
2021-06-03 12:51:01 -05:00
|
|
|
|
2023-08-04 14:01:49 -05:00
|
|
|
debuglevel = 0
|
|
|
|
|
|
|
|
CONTEXT_SETTINGS = {"help_option_names": ['-h', '--help']}
|
2021-06-03 12:51:01 -05:00
|
|
|
|
|
|
|
|
|
|
|
class AliasedGroup(click.Group):
|
|
|
|
def get_command(self, ctx, cmd_name):
|
|
|
|
rv = click.Group.get_command(self, ctx, cmd_name)
|
|
|
|
if rv is not None:
|
|
|
|
return rv
|
2023-08-04 14:01:49 -05:00
|
|
|
matches = [x for x in self.list_commands(ctx)
|
|
|
|
if x.startswith(cmd_name)]
|
2021-06-03 12:51:01 -05:00
|
|
|
if not matches:
|
|
|
|
return None
|
2023-08-04 14:01:49 -05:00
|
|
|
if len(matches) == 1:
|
2021-06-03 12:51:01 -05:00
|
|
|
return click.Group.get_command(self, ctx, matches[0])
|
2023-08-04 14:01:49 -05:00
|
|
|
ctx.fail('Too many matches: %s' % ', '.join(sorted(matches)))
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
def avscontrol_debug(s):
|
|
|
|
if AVSCTROLDEBUG & debuglevel:
|
|
|
|
syslog.openlog("AVSCONTROL", syslog.LOG_PID)
|
|
|
|
syslog.syslog(syslog.LOG_DEBUG, s)
|
|
|
|
|
|
|
|
|
|
|
|
def avscontrol_error(s):
|
|
|
|
if AVSCTROLERROR & debuglevel:
|
|
|
|
syslog.openlog("AVSCONTROL", syslog.LOG_PID)
|
|
|
|
syslog.syslog(syslog.LOG_ERR, s)
|
|
|
|
|
|
|
|
|
|
|
|
def avserror(s):
|
|
|
|
# s = s.decode('utf-8').encode('gb2312')
|
|
|
|
syslog.openlog("AVSCONTROL", syslog.LOG_PID)
|
|
|
|
syslog.syslog(syslog.LOG_ERR, s)
|
|
|
|
|
|
|
|
|
|
|
|
def avsinfo(s):
|
|
|
|
syslog.openlog("AVSCONTROL", syslog.LOG_PID)
|
|
|
|
syslog.syslog(syslog.LOG_INFO, s)
|
|
|
|
|
|
|
|
|
|
|
|
def debug_init():
|
|
|
|
global debuglevel
|
|
|
|
if os.path.exists(AVSCTROL_DEBUG_FILE):
|
|
|
|
debuglevel = debuglevel | AVSCTROLDEBUG | AVSCTROLERROR
|
|
|
|
else:
|
|
|
|
debuglevel = debuglevel & ~(AVSCTROLDEBUG | AVSCTROLERROR)
|
|
|
|
|
|
|
|
|
|
|
|
def set_avs_value_sysfs(conf, dcdc_value):
|
|
|
|
msg = ""
|
|
|
|
formula = conf.get("formula", None)
|
|
|
|
loc = conf.get("loc")
|
|
|
|
locations = glob.glob(loc)
|
|
|
|
if len(locations) == 0:
|
|
|
|
msg = "avs sysfs loc: %s not found" % loc
|
|
|
|
avscontrol_error(msg)
|
|
|
|
return False, msg
|
|
|
|
sysfs_loc = locations[0]
|
|
|
|
avscontrol_debug("set_avs_value_sysfs, loc: %s, origin dcdc value: %s, formula: %s" %
|
|
|
|
(sysfs_loc, dcdc_value, formula))
|
|
|
|
if formula is not None:
|
|
|
|
dcdc_value = get_format_value(formula % (dcdc_value))
|
|
|
|
wr_val = str(dcdc_value)
|
|
|
|
avscontrol_debug("set_avs_value_sysfs, write val: %s" % wr_val)
|
|
|
|
ret, log = write_sysfs(sysfs_loc, wr_val)
|
|
|
|
if ret is False:
|
|
|
|
msg = "set_avs_value_sysfs failed, msg: %s" % log
|
|
|
|
avscontrol_error(msg)
|
|
|
|
return ret, msg
|
|
|
|
|
|
|
|
|
|
|
|
def set_avs_value(avs_conf, dcdc_value):
|
|
|
|
set_avs_way = avs_conf.get("set_avs", {}).get("gettype")
|
|
|
|
if set_avs_way != "sysfs":
|
|
|
|
msg = "unsupport set avs value type: %s" % set_avs_way
|
|
|
|
avscontrol_error(msg)
|
|
|
|
return False, msg
|
|
|
|
ret, msg = set_avs_value_sysfs(avs_conf["set_avs"], dcdc_value)
|
|
|
|
return ret, msg
|
|
|
|
|
|
|
|
|
|
|
|
def get_dcdc_value(avs_conf, rov_value):
|
|
|
|
msg = ""
|
|
|
|
mac_avs_param = avs_conf.get("mac_avs_param", {})
|
|
|
|
if rov_value not in mac_avs_param.keys():
|
|
|
|
if avs_conf["type"] == 0:
|
|
|
|
msg = "VID:0x%x out of range, voltage regulate stop" % rov_value
|
|
|
|
avsinfo(msg)
|
|
|
|
return False, msg
|
|
|
|
dcdc_value = mac_avs_param[avs_conf["default"]]
|
|
|
|
avsinfo("VID:0x%x out of range, use default VID:0x%x" % (rov_value, dcdc_value))
|
|
|
|
else:
|
|
|
|
dcdc_value = mac_avs_param[rov_value]
|
|
|
|
return True, dcdc_value
|
|
|
|
|
|
|
|
|
|
|
|
def get_rov_value_cpld(avs_conf):
|
|
|
|
cpld_avs_config = avs_conf["cpld_avs"]
|
|
|
|
return get_value(cpld_avs_config)
|
|
|
|
|
|
|
|
|
|
|
|
def get_rov_value_sdk(avs_conf):
|
|
|
|
name = avs_conf["sdkreg"]
|
|
|
|
ret, status = getSdkReg(name)
|
|
|
|
if ret is False:
|
|
|
|
return False, status
|
|
|
|
status = int(status, 16)
|
|
|
|
# shift operation
|
|
|
|
if avs_conf["sdktype"] != 0:
|
|
|
|
status = (status >> avs_conf["macregloc"]) & avs_conf["mask"]
|
|
|
|
macavs = status
|
|
|
|
return True, macavs
|
|
|
|
|
|
|
|
|
|
|
|
def doAvsCtrol_single(avs_conf):
|
|
|
|
try:
|
|
|
|
avs_name = avs_conf.get("name")
|
|
|
|
rov_source = avs_conf["rov_source"]
|
|
|
|
if rov_source == 0:
|
|
|
|
ret, rov_value = get_rov_value_cpld(avs_conf) # get rov from cpld reg
|
2021-06-03 12:51:01 -05:00
|
|
|
else:
|
2023-08-04 14:01:49 -05:00
|
|
|
ret, rov_value = get_rov_value_sdk(avs_conf) # get rov from sdk reg
|
|
|
|
if ret is False:
|
|
|
|
msg = "%s get rov_value failed, msg: %s" % (avs_name, rov_value)
|
|
|
|
avscontrol_error(msg)
|
|
|
|
return False, msg
|
|
|
|
avscontrol_debug("%s rov_value: 0x%x" % (avs_name, rov_value))
|
|
|
|
ret, dcdc_value = get_dcdc_value(avs_conf, rov_value)
|
|
|
|
if ret is False:
|
|
|
|
msg = "%s get output voltage value failed, msg: %s" % (avs_name, dcdc_value)
|
|
|
|
avscontrol_error(msg)
|
|
|
|
return False, msg
|
|
|
|
ret, msg = set_avs_value(avs_conf, dcdc_value)
|
|
|
|
return ret, msg
|
|
|
|
except Exception as e:
|
|
|
|
msg = "%s avscontrol raise exception, msg: %s" % (avs_name, str(e))
|
|
|
|
avscontrol_error(msg)
|
|
|
|
return False, msg
|
|
|
|
|
|
|
|
|
|
|
|
def doAvsCtrol(avs_conf):
|
|
|
|
retry_time = avs_conf.get("retry", 10)
|
|
|
|
for i in range(retry_time):
|
|
|
|
debug_init()
|
|
|
|
ret, log = doAvsCtrol_single(avs_conf)
|
|
|
|
if ret is True:
|
|
|
|
return True, log
|
|
|
|
time.sleep(1)
|
|
|
|
return False, log
|
2021-06-03 12:51:01 -05:00
|
|
|
|
|
|
|
|
2023-08-04 14:01:49 -05:00
|
|
|
def run():
|
|
|
|
# wait 30s for device steady
|
|
|
|
time.sleep(30)
|
|
|
|
errcnt = 0
|
|
|
|
msg = ""
|
|
|
|
for item in MAC_DEFAULT_PARAM:
|
|
|
|
status, log = doAvsCtrol(item)
|
|
|
|
if status is False:
|
|
|
|
errcnt += 1
|
|
|
|
msg += log
|
2021-06-03 12:51:01 -05:00
|
|
|
|
2023-08-04 14:01:49 -05:00
|
|
|
if errcnt == 0:
|
|
|
|
avsinfo("%%AVSCONTROL success")
|
|
|
|
sys.exit(0)
|
|
|
|
avserror("%%DEV_MONITOR-AVS: MAC Voltage adjust failed.")
|
|
|
|
avserror("%%DEV_MONITOR-AVS: errmsg: %s" % msg)
|
|
|
|
sys.exit(1)
|
2021-06-03 12:51:01 -05:00
|
|
|
|
|
|
|
|
|
|
|
@click.group(cls=AliasedGroup, context_settings=CONTEXT_SETTINGS)
|
|
|
|
def main():
|
2023-08-04 14:01:49 -05:00
|
|
|
'''device operator'''
|
2021-06-03 12:51:01 -05:00
|
|
|
|
|
|
|
|
|
|
|
@main.command()
|
|
|
|
def start():
|
2023-08-04 14:01:49 -05:00
|
|
|
'''start AVS control'''
|
|
|
|
avsinfo("%%AVSCONTROL start")
|
|
|
|
run()
|
2021-06-03 12:51:01 -05:00
|
|
|
|
|
|
|
|
2023-08-04 14:01:49 -05:00
|
|
|
if __name__ == '__main__':
|
2021-06-03 12:51:01 -05:00
|
|
|
main()
|