2019-05-19 00:11:38 -05:00
|
|
|
#!/usr/bin/env python
|
2019-11-07 23:53:21 -06:00
|
|
|
# Copyright (c) 2019 Edgecore Networks Corporation
|
2019-05-19 00:11:38 -05:00
|
|
|
#
|
2019-11-07 23:53:21 -06:00
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
# not use this file except in compliance with the License. You may obtain
|
|
|
|
# a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
2019-05-19 00:11:38 -05:00
|
|
|
#
|
2019-11-07 23:53:21 -06:00
|
|
|
# THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR
|
|
|
|
# CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT
|
|
|
|
# LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF TITLE, FITNESS
|
|
|
|
# FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR NON-INFRINGEMENT.
|
2019-05-19 00:11:38 -05:00
|
|
|
#
|
2019-11-07 23:53:21 -06:00
|
|
|
# See the Apache Version 2.0 License for specific language governing
|
|
|
|
# permissions and limitations under the License.
|
2019-05-19 00:11:38 -05:00
|
|
|
#
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
# HISTORY:
|
|
|
|
# mm/dd/yyyy (A.D.)
|
2019-11-07 23:53:21 -06:00
|
|
|
# 10/24/2019:Jostar craete for as4630_54pe
|
2019-05-19 00:11:38 -05:00
|
|
|
# ------------------------------------------------------------------
|
|
|
|
|
|
|
|
try:
|
|
|
|
import logging
|
|
|
|
except ImportError as e:
|
|
|
|
raise ImportError('%s - required module not found' % str(e))
|
2020-03-25 13:58:19 -05:00
|
|
|
|
|
|
|
|
|
|
|
class FanUtil(object):
|
|
|
|
"""Platform-specific FanUtil class"""
|
|
|
|
|
|
|
|
FAN_NUM_ON_MAIN_BROAD = 3
|
|
|
|
FAN_NUM_1_IDX = 1
|
|
|
|
FAN_NUM_2_IDX = 2
|
|
|
|
FAN_NUM_3_IDX = 3
|
2019-05-19 00:11:38 -05:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
FAN_NODE_NUM_OF_MAP = 4
|
|
|
|
FAN_NODE_FAULT_IDX_OF_MAP = 1
|
|
|
|
FAN_NODE_DIR_IDX_OF_MAP = 2
|
|
|
|
FAN_NODE_PRESENT_IDX_OF_MAP= 3
|
|
|
|
FAN_NODE_SPEED_IDX_OF_MAP = 4
|
|
|
|
|
|
|
|
BASE_VAL_PATH = '/sys/bus/i2c/devices/3-0060/{0}'
|
|
|
|
FAN_DUTY_PATH = '/sys/bus/i2c/devices/3-0060/fan_duty_cycle_percentage'
|
2019-05-19 00:11:38 -05:00
|
|
|
|
|
|
|
""" Dictionary where
|
2020-03-25 13:58:19 -05:00
|
|
|
key1 = fan id index (integer) starting from 1
|
|
|
|
key2 = fan node index (interger) starting from 1
|
2019-05-19 00:11:38 -05:00
|
|
|
value = path to fan device file (string) """
|
2020-03-25 13:58:19 -05:00
|
|
|
_fan_device_path_mapping = {}
|
2019-11-07 23:53:21 -06:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
_fan_device_node_mapping = {
|
|
|
|
(FAN_NUM_1_IDX, FAN_NODE_FAULT_IDX_OF_MAP): 'fan_fault_1',
|
|
|
|
(FAN_NUM_1_IDX, FAN_NODE_DIR_IDX_OF_MAP): 'fan_direction_1',
|
|
|
|
(FAN_NUM_1_IDX, FAN_NODE_PRESENT_IDX_OF_MAP): 'fan_present_1',
|
|
|
|
(FAN_NUM_1_IDX, FAN_NODE_SPEED_IDX_OF_MAP): 'fan1_input',
|
|
|
|
|
|
|
|
|
|
|
|
(FAN_NUM_2_IDX, FAN_NODE_FAULT_IDX_OF_MAP): 'fan_fault_2',
|
|
|
|
(FAN_NUM_2_IDX, FAN_NODE_DIR_IDX_OF_MAP): 'fan_direction_2',
|
|
|
|
(FAN_NUM_2_IDX, FAN_NODE_PRESENT_IDX_OF_MAP):'fan_present_2',
|
|
|
|
(FAN_NUM_2_IDX, FAN_NODE_SPEED_IDX_OF_MAP): 'fan2_input',
|
|
|
|
|
|
|
|
(FAN_NUM_3_IDX, FAN_NODE_FAULT_IDX_OF_MAP): 'fan_fault_3',
|
|
|
|
(FAN_NUM_3_IDX, FAN_NODE_DIR_IDX_OF_MAP): 'fan_direction_3',
|
|
|
|
(FAN_NUM_3_IDX, FAN_NODE_PRESENT_IDX_OF_MAP):'fan_present_3',
|
|
|
|
(FAN_NUM_3_IDX, FAN_NODE_SPEED_IDX_OF_MAP): 'fan3_input',
|
2019-11-07 23:53:21 -06:00
|
|
|
}
|
2019-05-19 00:11:38 -05:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
def _get_fan_device_node(self, fan_num, node_num):
|
|
|
|
return self._fan_device_node_mapping[(fan_num, node_num)]
|
|
|
|
|
|
|
|
def _get_fan_node_val(self, fan_num, node_num):
|
|
|
|
if fan_num < self.FAN_NUM_1_IDX or fan_num > self.FAN_NUM_ON_MAIN_BROAD:
|
|
|
|
logging.debug('GET. Parameter error. fan_num:%d', fan_num)
|
|
|
|
return None
|
|
|
|
|
|
|
|
if node_num < self.FAN_NODE_FAULT_IDX_OF_MAP or node_num > self.FAN_NODE_NUM_OF_MAP:
|
|
|
|
logging.debug('GET. Parameter error. node_num:%d', node_num)
|
2019-05-19 00:11:38 -05:00
|
|
|
return None
|
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
device_path = self.get_fan_device_path(fan_num, node_num)
|
|
|
|
|
2021-09-28 13:26:50 -05:00
|
|
|
try:
|
|
|
|
val_file = open(device_path, 'r')
|
|
|
|
except IOError as e:
|
|
|
|
logging.error('GET. unable to open file: %s', str(e))
|
|
|
|
return None
|
|
|
|
|
|
|
|
content = val_file.readline().rstrip()
|
|
|
|
if content == '':
|
|
|
|
logging.debug('GET. content is NULL. device_path:%s', device_path)
|
|
|
|
return None
|
|
|
|
|
|
|
|
try:
|
|
|
|
val_file.close()
|
|
|
|
except IOError as e:
|
|
|
|
logging.debug('GET. unable to close file: %s. device_path:%s', str(e), device_path)
|
|
|
|
return None
|
|
|
|
|
|
|
|
return int(content)
|
2019-11-07 23:53:21 -06:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
def _set_fan_node_val(self, fan_num, node_num, val):
|
|
|
|
if fan_num < self.FAN_NUM_1_IDX or fan_num > self.FAN_NUM_ON_MAIN_BROAD:
|
|
|
|
logging.debug('GET. Parameter error. fan_num:%d', fan_num)
|
|
|
|
return None
|
2019-05-19 00:11:38 -05:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
if node_num < self.FAN_NODE_FAULT_IDX_OF_MAP or node_num > self.FAN_NODE_NUM_OF_MAP:
|
|
|
|
logging.debug('GET. Parameter error. node_num:%d', node_num)
|
|
|
|
return None
|
|
|
|
|
|
|
|
content = str(val)
|
|
|
|
if content == '':
|
|
|
|
logging.debug('GET. content is NULL. device_path:%s', device_path)
|
|
|
|
return None
|
2019-05-19 00:11:38 -05:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
device_path = self.get_fan_device_path(fan_num, node_num)
|
|
|
|
try:
|
|
|
|
val_file = open(device_path, 'w')
|
|
|
|
except IOError as e:
|
|
|
|
logging.error('GET. unable to open file: %s', str(e))
|
|
|
|
return None
|
2019-10-16 20:01:38 -05:00
|
|
|
|
2020-03-25 13:58:19 -05:00
|
|
|
val_file.write(content)
|
|
|
|
|
|
|
|
try:
|
2021-09-28 13:26:50 -05:00
|
|
|
val_file.close()
|
|
|
|
except IOError as e:
|
|
|
|
logging.debug('GET. unable to close file: %s. device_path:%s', str(e), device_path)
|
2020-03-25 13:58:19 -05:00
|
|
|
return None
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
fan_path = self.BASE_VAL_PATH
|
|
|
|
for fan_num in range(self.FAN_NUM_1_IDX, self.FAN_NUM_ON_MAIN_BROAD+1):
|
|
|
|
for node_num in range(self.FAN_NODE_FAULT_IDX_OF_MAP, self.FAN_NODE_NUM_OF_MAP+1):
|
|
|
|
self._fan_device_path_mapping[(fan_num, node_num)] = fan_path.format(
|
|
|
|
self._fan_device_node_mapping[(fan_num, node_num)])
|
|
|
|
|
|
|
|
def get_size_node_map(self):
|
|
|
|
return len(self._fan_device_node_mapping)
|
|
|
|
|
|
|
|
def get_fan_device_path(self, fan_num, node_num):
|
|
|
|
return self._fan_device_path_mapping[(fan_num, node_num)]
|
|
|
|
|
|
|
|
def get_fan_fault(self, fan_num):
|
|
|
|
return self._get_fan_node_val(fan_num, self.FAN_NODE_FAULT_IDX_OF_MAP)
|
|
|
|
|
|
|
|
def get_fan_present(self, fan_num):
|
|
|
|
return self._get_fan_node_val(fan_num, self.FAN_NODE_PRESENT_IDX_OF_MAP)
|
|
|
|
|
|
|
|
def get_fan_dir(self, fan_num):
|
|
|
|
return self._get_fan_node_val(fan_num, self.FAN_NODE_DIR_IDX_OF_MAP)
|
|
|
|
|
|
|
|
def get_fan_duty_cycle(self):
|
|
|
|
try:
|
|
|
|
val_file = open(self.FAN_DUTY_PATH)
|
|
|
|
except IOError as e:
|
2021-09-28 13:26:50 -05:00
|
|
|
print("Error: unable to open file: %s" % str(e))
|
2020-03-25 13:58:19 -05:00
|
|
|
return False
|
|
|
|
|
|
|
|
content = val_file.readline().rstrip()
|
|
|
|
val_file.close()
|
|
|
|
|
|
|
|
return int(content)
|
|
|
|
|
|
|
|
def set_fan_duty_cycle(self, val):
|
|
|
|
try:
|
|
|
|
fan_file = open(self.FAN_DUTY_PATH, 'r+')
|
|
|
|
except IOError as e:
|
2021-09-28 13:26:50 -05:00
|
|
|
print("Error: unable to open file: %s" % str(e))
|
2020-03-25 13:58:19 -05:00
|
|
|
return False
|
|
|
|
|
|
|
|
fan_file.write(str(val))
|
|
|
|
fan_file.close()
|
|
|
|
return True
|
|
|
|
|
|
|
|
def get_fan_speed(self, fan_num):
|
|
|
|
return self._get_fan_node_val(fan_num, self.FAN_NODE_SPEED_IDX_OF_MAP)
|
|
|
|
|
|
|
|
def get_fan_status(self, fan_num):
|
|
|
|
if fan_num < self.FAN_NUM_1_IDX or fan_num > self.FAN_NUM_ON_MAIN_BROAD:
|
|
|
|
logging.debug('GET. Parameter error. fan_num, %d', fan_num)
|
|
|
|
return None
|
|
|
|
if self.get_fan_fault(fan_num)==0 and self.get_fan_present(fan_num)>0:
|
|
|
|
return 1
|
|
|
|
else:
|
|
|
|
logging.debug('GET. FAN fault. fan_num, %d', fan_num)
|
|
|
|
return 0
|
2019-05-19 00:11:38 -05:00
|
|
|
|
2019-11-07 23:53:21 -06:00
|
|
|
def main():
|
2020-03-25 13:58:19 -05:00
|
|
|
fan = FanUtil()
|
|
|
|
logging.debug('fan_duty_cycle=%d', fan.get_fan_duty_cycle())
|
|
|
|
for i in range(1,4):
|
|
|
|
logging.debug('fan-%d speed=%d', i, fan.get_fan_speed(i))
|
|
|
|
logging.debug('fan-%d present=%d', i, fan.get_fan_present(i))
|
|
|
|
logging.debug('fan-%d fault=%d', i, fan.get_fan_fault(i))
|
|
|
|
logging.debug('fan-%d status=%d', i, fan.get_fan_status(i))
|
2019-11-07 23:53:21 -06:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2020-04-09 01:04:13 -05:00
|
|
|
main()
|