晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /lib/python3.6/site-packages/sos/report/plugins/ |
Upload File : |
# Copyright (C) 2023 Nvidia Corporation, Alin Serdean <aserdean@nvidia.com>
# This file is part of the sos project: https://github.com/sosreport/sos
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# version 2 of the GNU General Public License.
#
# See the LICENSE file in the source distribution for further information.
import os
import time
from sos.report.plugins import Plugin, IndependentPlugin
class MellanoxFirmware(Plugin, IndependentPlugin):
short_desc = 'Nvidia(Mellanox) firmware tools output'
plugin_name = "mellanox_firmware"
profiles = ('hardware', 'system')
packages = ('mst', 'mstflint')
MLNX_STRING = "Mellanox Technologies"
def check_enabled(self):
"""
Checks if this plugin should be executed at all.
We will only enable the plugin if there is a
Mellanox Technologies network adapter
"""
lspci = self.exec_cmd("lspci -D -d 15b3::0200")
return lspci['status'] == 0 and self.MLNX_STRING in lspci['output']
def collect(self):
if not self.get_option('allow_system_changes'):
self._log_info("Skipping mst/mlx cable commands as system changes"
"would be made. Use --allow-system-changes to"
"enable this collection.")
return
# Run only if mft package is installed.
# flint is available from the mft package.
cout = self.exec_cmd('flint --version')
if cout['status'] != 0:
return
cout = self.collect_cmd_output('mst start')
if cout['status'] != 0:
return
self.collect_cmd_output('mst cable add')
self.collect_cmd_output("mst status -v", timeout=10)
self.collect_cmd_output("mlxcables", timeout=10)
cout = os.listdir("/dev/mst")
mlxcables = []
for device in cout:
if 'cable' in device:
mlxcables.append(device)
for mlxcable in mlxcables:
self.collect_cmd_output(f"mlxcables -d {mlxcable} --DDM",
timeout=10)
self.collect_cmd_output(f"mlxcables -d {mlxcable} --dump",
timeout=10)
self.collect_cmd_output("mst stop", changes=True)
def setup(self):
# Get all devices which have the vendor Mellanox Technologies
devices = []
device_list = self.collect_cmd_output('lspci -D -d 15b3::0200')
# Will return a string of the following format:
# 0000:08:00.0 Ethernet controller: Mellanox Technologies MT2892 Family
if device_list['status'] != 0:
# bail out if there no Mellanox PCI devices
return
for line in device_list["output"].splitlines():
# Should return 0000:08:00.0
# from the following string
# 0000:08:00.0 Ethernet controller: Mellanox Technologies MT2892
# Family
devices.append(line[0:8]+'00.0')
devices = set(devices)
# Mft package is present if OFED is installed
# mstflint package is part of the distro and can be installed.
commands = []
# mft package is installed if flint command is available
cout = self.exec_cmd('flint --version')
if cout['status'] != 0:
# mstflint package commands
# the commands do not support position independent arguments
commands = [
["mstconfig -d ", " -e q"],
["mstflint -d ", " dc"],
["mstflint -d ", " q"],
["mstreg -d ", " --reg_name ROCE_ACCL --get"],
["mstlink -d ", ""],
]
else:
# mft package commands
# the commands do not support position independent arguments
commands = [
["mlxdump -d ", " pcie_uc --all"],
["mstconfig -d ", " -e q"],
["flint -d ", " dc"],
["flint -d ", " q"],
["mlxreg -d ", " --reg_name ROCE_ACCL --get"],
["mlxlink -d ", ""],
["fwtrace -d ", " -i all --tracer_mode FIFO"],
]
for device in devices:
for command in commands:
self.add_cmd_output(f"{command[0]} {device} "
f"{command[1]}", timeout=30)
# Dump the output of the mstdump command three times
# waiting for one second. This output is useful to check
# if certain registers changed
for _ in range(3):
self.add_cmd_output(f"mstdump {device}")
time.sleep(1)
# vim: set et ts=4 sw=4 :