mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	net: hns3: refactor the debugfs process
Currently, each debugfs command needs to create a file to get the information. To better support more debugfs commands, the debugfs process is reconstructed, including the process of creating dentries and files, and obtaining information. Signed-off-by: Yufeng Mo <moyufeng@huawei.com> Signed-off-by: Huazhong Tan <tanhuazhong@huawei.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									1ddc028ac8
								
							
						
					
					
						commit
						5e69ea7ee2
					
				| @ -250,6 +250,13 @@ enum hnae3_port_base_vlan_state { | |||||||
| 	HNAE3_PORT_BASE_VLAN_NOCHANGE, | 	HNAE3_PORT_BASE_VLAN_NOCHANGE, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | enum hnae3_dbg_cmd { | ||||||
|  | 	HNAE3_DBG_CMD_TM_NODES, | ||||||
|  | 	HNAE3_DBG_CMD_TM_PRI, | ||||||
|  | 	HNAE3_DBG_CMD_TM_QSET, | ||||||
|  | 	HNAE3_DBG_CMD_UNKNOWN, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| struct hnae3_vector_info { | struct hnae3_vector_info { | ||||||
| 	u8 __iomem *io_addr; | 	u8 __iomem *io_addr; | ||||||
| 	int vector; | 	int vector; | ||||||
| @ -627,7 +634,7 @@ struct hnae3_ae_ops { | |||||||
| 	int (*add_arfs_entry)(struct hnae3_handle *handle, u16 queue_id, | 	int (*add_arfs_entry)(struct hnae3_handle *handle, u16 queue_id, | ||||||
| 			      u16 flow_id, struct flow_keys *fkeys); | 			      u16 flow_id, struct flow_keys *fkeys); | ||||||
| 	int (*dbg_run_cmd)(struct hnae3_handle *handle, const char *cmd_buf); | 	int (*dbg_run_cmd)(struct hnae3_handle *handle, const char *cmd_buf); | ||||||
| 	int (*dbg_read_cmd)(struct hnae3_handle *handle, const char *cmd_buf, | 	int (*dbg_read_cmd)(struct hnae3_handle *handle, enum hnae3_dbg_cmd cmd, | ||||||
| 			    char *buf, int len); | 			    char *buf, int len); | ||||||
| 	pci_ers_result_t (*handle_hw_ras_error)(struct hnae3_ae_dev *ae_dev); | 	pci_ers_result_t (*handle_hw_ras_error)(struct hnae3_ae_dev *ae_dev); | ||||||
| 	bool (*get_hw_reset_stat)(struct hnae3_handle *handle); | 	bool (*get_hw_reset_stat)(struct hnae3_handle *handle); | ||||||
| @ -790,10 +797,6 @@ struct hnae3_handle { | |||||||
| #define hnae3_get_bit(origin, shift) \ | #define hnae3_get_bit(origin, shift) \ | ||||||
| 	hnae3_get_field(origin, 0x1 << (shift), shift) | 	hnae3_get_field(origin, 0x1 << (shift), shift) | ||||||
| 
 | 
 | ||||||
| #define HNAE3_DBG_TM_NODES		"tm_nodes" |  | ||||||
| #define HNAE3_DBG_TM_PRI		"tm_priority" |  | ||||||
| #define HNAE3_DBG_TM_QSET		"tm_qset" |  | ||||||
| 
 |  | ||||||
| int hnae3_register_ae_dev(struct hnae3_ae_dev *ae_dev); | int hnae3_register_ae_dev(struct hnae3_ae_dev *ae_dev); | ||||||
| void hnae3_unregister_ae_dev(struct hnae3_ae_dev *ae_dev); | void hnae3_unregister_ae_dev(struct hnae3_ae_dev *ae_dev); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,13 +5,48 @@ | |||||||
| #include <linux/device.h> | #include <linux/device.h> | ||||||
| 
 | 
 | ||||||
| #include "hnae3.h" | #include "hnae3.h" | ||||||
|  | #include "hns3_debugfs.h" | ||||||
| #include "hns3_enet.h" | #include "hns3_enet.h" | ||||||
| 
 | 
 | ||||||
| #define HNS3_DBG_READ_LEN 65536 |  | ||||||
| #define HNS3_DBG_WRITE_LEN 1024 |  | ||||||
| 
 |  | ||||||
| static struct dentry *hns3_dbgfs_root; | static struct dentry *hns3_dbgfs_root; | ||||||
| 
 | 
 | ||||||
|  | static struct hns3_dbg_dentry_info hns3_dbg_dentry[] = { | ||||||
|  | 	{ | ||||||
|  | 		.name = "tm" | ||||||
|  | 	}, | ||||||
|  | 	/* keep common at the bottom and add new directory above */ | ||||||
|  | 	{ | ||||||
|  | 		.name = "common" | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | static int hns3_dbg_common_file_init(struct hnae3_handle *handle, | ||||||
|  | 				     unsigned int cmd); | ||||||
|  | 
 | ||||||
|  | static struct hns3_dbg_cmd_info hns3_dbg_cmd[] = { | ||||||
|  | 	{ | ||||||
|  | 		.name = "tm_nodes", | ||||||
|  | 		.cmd = HNAE3_DBG_CMD_TM_NODES, | ||||||
|  | 		.dentry = HNS3_DBG_DENTRY_TM, | ||||||
|  | 		.buf_len = HNS3_DBG_READ_LEN, | ||||||
|  | 		.init = hns3_dbg_common_file_init, | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		.name = "tm_priority", | ||||||
|  | 		.cmd = HNAE3_DBG_CMD_TM_PRI, | ||||||
|  | 		.dentry = HNS3_DBG_DENTRY_TM, | ||||||
|  | 		.buf_len = HNS3_DBG_READ_LEN, | ||||||
|  | 		.init = hns3_dbg_common_file_init, | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		.name = "tm_qset", | ||||||
|  | 		.cmd = HNAE3_DBG_CMD_TM_QSET, | ||||||
|  | 		.dentry = HNS3_DBG_DENTRY_TM, | ||||||
|  | 		.buf_len = HNS3_DBG_READ_LEN, | ||||||
|  | 		.init = hns3_dbg_common_file_init, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| static int hns3_dbg_queue_info(struct hnae3_handle *h, | static int hns3_dbg_queue_info(struct hnae3_handle *h, | ||||||
| 			       const char *cmd_buf) | 			       const char *cmd_buf) | ||||||
| { | { | ||||||
| @ -493,37 +528,90 @@ static ssize_t hns3_dbg_cmd_write(struct file *filp, const char __user *buffer, | |||||||
| 	return count; | 	return count; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static int hns3_dbg_get_cmd_index(struct hnae3_handle *handle, | ||||||
|  | 				  const unsigned char *name, u32 *index) | ||||||
|  | { | ||||||
|  | 	u32 i; | ||||||
|  | 
 | ||||||
|  | 	for (i = 0; i < ARRAY_SIZE(hns3_dbg_cmd); i++) { | ||||||
|  | 		if (!strncmp(name, hns3_dbg_cmd[i].name, | ||||||
|  | 			     strlen(hns3_dbg_cmd[i].name))) { | ||||||
|  | 			*index = i; | ||||||
|  | 			return 0; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	dev_err(&handle->pdev->dev, "unknown command(%s)\n", name); | ||||||
|  | 	return -EINVAL; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int hns3_dbg_read_cmd(struct hnae3_handle *handle, | ||||||
|  | 			     enum hnae3_dbg_cmd cmd, char *buf, int len) | ||||||
|  | { | ||||||
|  | 	const struct hnae3_ae_ops *ops = handle->ae_algo->ops; | ||||||
|  | 
 | ||||||
|  | 	if (!ops->dbg_read_cmd) | ||||||
|  | 		return -EOPNOTSUPP; | ||||||
|  | 
 | ||||||
|  | 	return ops->dbg_read_cmd(handle, cmd, buf, len); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer, | static ssize_t hns3_dbg_read(struct file *filp, char __user *buffer, | ||||||
| 			     size_t count, loff_t *ppos) | 			     size_t count, loff_t *ppos) | ||||||
| { | { | ||||||
| 	struct hnae3_handle *handle = filp->private_data; | 	struct hnae3_handle *handle = filp->private_data; | ||||||
| 	const struct hnae3_ae_ops *ops = handle->ae_algo->ops; |  | ||||||
| 	struct hns3_nic_priv *priv = handle->priv; | 	struct hns3_nic_priv *priv = handle->priv; | ||||||
| 	char *cmd_buf, *read_buf; |  | ||||||
| 	ssize_t size = 0; | 	ssize_t size = 0; | ||||||
| 	int ret = 0; | 	char **save_buf; | ||||||
|  | 	char *read_buf; | ||||||
|  | 	u32 index; | ||||||
|  | 	int ret; | ||||||
| 
 | 
 | ||||||
| 	read_buf = kzalloc(HNS3_DBG_READ_LEN, GFP_KERNEL); | 	ret = hns3_dbg_get_cmd_index(handle, filp->f_path.dentry->d_iname, | ||||||
|  | 				     &index); | ||||||
|  | 	if (ret) | ||||||
|  | 		return ret; | ||||||
|  | 
 | ||||||
|  | 	save_buf = &hns3_dbg_cmd[index].buf; | ||||||
|  | 
 | ||||||
|  | 	if (!test_bit(HNS3_NIC_STATE_INITED, &priv->state) || | ||||||
|  | 	    test_bit(HNS3_NIC_STATE_RESETTING, &priv->state)) { | ||||||
|  | 		ret = -EBUSY; | ||||||
|  | 		goto out; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (*save_buf) { | ||||||
|  | 		read_buf = *save_buf; | ||||||
|  | 	} else { | ||||||
|  | 		read_buf = kvzalloc(hns3_dbg_cmd[index].buf_len, GFP_KERNEL); | ||||||
| 		if (!read_buf) | 		if (!read_buf) | ||||||
| 			return -ENOMEM; | 			return -ENOMEM; | ||||||
| 
 | 
 | ||||||
| 	cmd_buf = filp->f_path.dentry->d_iname; | 		/* save the buffer addr until the last read operation */ | ||||||
|  | 		*save_buf = read_buf; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (ops->dbg_read_cmd) | 	/* get data ready for the first time to read */ | ||||||
| 		ret = ops->dbg_read_cmd(handle, cmd_buf, read_buf, | 	if (!*ppos) { | ||||||
| 					HNS3_DBG_READ_LEN); | 		ret = hns3_dbg_read_cmd(handle, hns3_dbg_cmd[index].cmd, | ||||||
| 
 | 					read_buf, hns3_dbg_cmd[index].buf_len); | ||||||
| 	if (ret) { | 		if (ret) | ||||||
| 		dev_info(priv->dev, "unknown command\n"); |  | ||||||
| 			goto out; | 			goto out; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	size = simple_read_from_buffer(buffer, count, ppos, read_buf, | 	size = simple_read_from_buffer(buffer, count, ppos, read_buf, | ||||||
| 				       strlen(read_buf)); | 				       strlen(read_buf)); | ||||||
|  | 	if (size > 0) | ||||||
|  | 		return size; | ||||||
| 
 | 
 | ||||||
| out: | out: | ||||||
| 	kfree(read_buf); | 	/* free the buffer for the last read operation */ | ||||||
| 	return size; | 	if (*save_buf) { | ||||||
|  | 		kvfree(*save_buf); | ||||||
|  | 		*save_buf = NULL; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static const struct file_operations hns3_dbg_cmd_fops = { | static const struct file_operations hns3_dbg_cmd_fops = { | ||||||
| @ -539,29 +627,76 @@ static const struct file_operations hns3_dbg_fops = { | |||||||
| 	.read  = hns3_dbg_read, | 	.read  = hns3_dbg_read, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| void hns3_dbg_init(struct hnae3_handle *handle) | static int | ||||||
|  | hns3_dbg_common_file_init(struct hnae3_handle *handle, u32 cmd) | ||||||
|  | { | ||||||
|  | 	struct dentry *entry_dir; | ||||||
|  | 
 | ||||||
|  | 	entry_dir = hns3_dbg_dentry[hns3_dbg_cmd[cmd].dentry].dentry; | ||||||
|  | 	debugfs_create_file(hns3_dbg_cmd[cmd].name, 0400, entry_dir, | ||||||
|  | 			    handle, &hns3_dbg_fops); | ||||||
|  | 
 | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int hns3_dbg_init(struct hnae3_handle *handle) | ||||||
| { | { | ||||||
| 	struct hnae3_ae_dev *ae_dev = pci_get_drvdata(handle->pdev); | 	struct hnae3_ae_dev *ae_dev = pci_get_drvdata(handle->pdev); | ||||||
| 	const char *name = pci_name(handle->pdev); | 	const char *name = pci_name(handle->pdev); | ||||||
| 	struct dentry *entry_dir; | 	int ret; | ||||||
|  | 	u32 i; | ||||||
| 
 | 
 | ||||||
| 	handle->hnae3_dbgfs = debugfs_create_dir(name, hns3_dbgfs_root); | 	hns3_dbg_dentry[HNS3_DBG_DENTRY_COMMON].dentry = | ||||||
|  | 				debugfs_create_dir(name, hns3_dbgfs_root); | ||||||
|  | 	handle->hnae3_dbgfs = hns3_dbg_dentry[HNS3_DBG_DENTRY_COMMON].dentry; | ||||||
| 
 | 
 | ||||||
| 	debugfs_create_file("cmd", 0600, handle->hnae3_dbgfs, handle, | 	debugfs_create_file("cmd", 0600, handle->hnae3_dbgfs, handle, | ||||||
| 			    &hns3_dbg_cmd_fops); | 			    &hns3_dbg_cmd_fops); | ||||||
| 
 | 
 | ||||||
| 	entry_dir = debugfs_create_dir("tm", handle->hnae3_dbgfs); | 	for (i = 0; i < HNS3_DBG_DENTRY_COMMON; i++) | ||||||
| 	if (ae_dev->dev_version > HNAE3_DEVICE_VERSION_V2) | 		hns3_dbg_dentry[i].dentry = | ||||||
| 		debugfs_create_file(HNAE3_DBG_TM_NODES, 0600, entry_dir, handle, | 			debugfs_create_dir(hns3_dbg_dentry[i].name, | ||||||
| 				    &hns3_dbg_fops); | 					   handle->hnae3_dbgfs); | ||||||
| 	debugfs_create_file(HNAE3_DBG_TM_PRI, 0600, entry_dir, handle, | 
 | ||||||
| 			    &hns3_dbg_fops); | 	for (i = 0; i < ARRAY_SIZE(hns3_dbg_cmd); i++) { | ||||||
| 	debugfs_create_file(HNAE3_DBG_TM_QSET, 0600, entry_dir, handle, | 		if (hns3_dbg_cmd[i].cmd == HNAE3_DBG_CMD_TM_NODES && | ||||||
| 			    &hns3_dbg_fops); | 		    ae_dev->dev_version <= HNAE3_DEVICE_VERSION_V2) | ||||||
|  | 			continue; | ||||||
|  | 
 | ||||||
|  | 		if (!hns3_dbg_cmd[i].init) { | ||||||
|  | 			dev_err(&handle->pdev->dev, | ||||||
|  | 				"cmd %s lack of init func\n", | ||||||
|  | 				hns3_dbg_cmd[i].name); | ||||||
|  | 			ret = -EINVAL; | ||||||
|  | 			goto out; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		ret = hns3_dbg_cmd[i].init(handle, i); | ||||||
|  | 		if (ret) { | ||||||
|  | 			dev_err(&handle->pdev->dev, "failed to init cmd %s\n", | ||||||
|  | 				hns3_dbg_cmd[i].name); | ||||||
|  | 			goto out; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	return 0; | ||||||
|  | 
 | ||||||
|  | out: | ||||||
|  | 	debugfs_remove_recursive(handle->hnae3_dbgfs); | ||||||
|  | 	handle->hnae3_dbgfs = NULL; | ||||||
|  | 	return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void hns3_dbg_uninit(struct hnae3_handle *handle) | void hns3_dbg_uninit(struct hnae3_handle *handle) | ||||||
| { | { | ||||||
|  | 	u32 i; | ||||||
|  | 
 | ||||||
|  | 	for (i = 0; i < ARRAY_SIZE(hns3_dbg_cmd); i++) | ||||||
|  | 		if (hns3_dbg_cmd[i].buf) { | ||||||
|  | 			kvfree(hns3_dbg_cmd[i].buf); | ||||||
|  | 			hns3_dbg_cmd[i].buf = NULL; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 	debugfs_remove_recursive(handle->hnae3_dbgfs); | 	debugfs_remove_recursive(handle->hnae3_dbgfs); | ||||||
| 	handle->hnae3_dbgfs = NULL; | 	handle->hnae3_dbgfs = NULL; | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										29
									
								
								drivers/net/ethernet/hisilicon/hns3/hns3_debugfs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								drivers/net/ethernet/hisilicon/hns3/hns3_debugfs.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | /* SPDX-License-Identifier: GPL-2.0+ */ | ||||||
|  | /* Copyright (c) 2021 Hisilicon Limited. */ | ||||||
|  | 
 | ||||||
|  | #ifndef __HNS3_DEBUGFS_H | ||||||
|  | #define __HNS3_DEBUGFS_H | ||||||
|  | 
 | ||||||
|  | #define HNS3_DBG_READ_LEN	65536 | ||||||
|  | #define HNS3_DBG_WRITE_LEN	1024 | ||||||
|  | 
 | ||||||
|  | enum hns3_dbg_dentry_type { | ||||||
|  | 	HNS3_DBG_DENTRY_TM, | ||||||
|  | 	HNS3_DBG_DENTRY_COMMON, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | struct hns3_dbg_dentry_info { | ||||||
|  | 	const char *name; | ||||||
|  | 	struct dentry *dentry; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | struct hns3_dbg_cmd_info { | ||||||
|  | 	const char *name; | ||||||
|  | 	enum hnae3_dbg_cmd cmd; | ||||||
|  | 	enum hns3_dbg_dentry_type dentry; | ||||||
|  | 	u32 buf_len; | ||||||
|  | 	char *buf; | ||||||
|  | 	int (*init)(struct hnae3_handle *handle, unsigned int cmd); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
| @ -4648,7 +4648,12 @@ static int hns3_client_init(struct hnae3_handle *handle) | |||||||
| 
 | 
 | ||||||
| 	hns3_dcbnl_setup(handle); | 	hns3_dcbnl_setup(handle); | ||||||
| 
 | 
 | ||||||
| 	hns3_dbg_init(handle); | 	ret = hns3_dbg_init(handle); | ||||||
|  | 	if (ret) { | ||||||
|  | 		dev_err(priv->dev, "failed to init debugfs, ret = %d\n", | ||||||
|  | 			ret); | ||||||
|  | 		goto out_client_start; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	netdev->max_mtu = HNS3_MAX_MTU(ae_dev->dev_specs.max_frm_size); | 	netdev->max_mtu = HNS3_MAX_MTU(ae_dev->dev_specs.max_frm_size); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -650,7 +650,7 @@ void hns3_dcbnl_setup(struct hnae3_handle *handle); | |||||||
| static inline void hns3_dcbnl_setup(struct hnae3_handle *handle) {} | static inline void hns3_dcbnl_setup(struct hnae3_handle *handle) {} | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| void hns3_dbg_init(struct hnae3_handle *handle); | int hns3_dbg_init(struct hnae3_handle *handle); | ||||||
| void hns3_dbg_uninit(struct hnae3_handle *handle); | void hns3_dbg_uninit(struct hnae3_handle *handle); | ||||||
| void hns3_dbg_register_debugfs(const char *debugfs_dir_name); | void hns3_dbg_register_debugfs(const char *debugfs_dir_name); | ||||||
| void hns3_dbg_unregister_debugfs(void); | void hns3_dbg_unregister_debugfs(void); | ||||||
|  | |||||||
| @ -1800,21 +1800,33 @@ int hclge_dbg_run_cmd(struct hnae3_handle *handle, const char *cmd_buf) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int hclge_dbg_read_cmd(struct hnae3_handle *handle, const char *cmd_buf, | static const struct hclge_dbg_func hclge_dbg_cmd_func[] = { | ||||||
|  | 	{ | ||||||
|  | 		.cmd = HNAE3_DBG_CMD_TM_NODES, | ||||||
|  | 		.dbg_dump = hclge_dbg_dump_tm_nodes, | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		.cmd = HNAE3_DBG_CMD_TM_PRI, | ||||||
|  | 		.dbg_dump = hclge_dbg_dump_tm_pri, | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		.cmd = HNAE3_DBG_CMD_TM_QSET, | ||||||
|  | 		.dbg_dump = hclge_dbg_dump_tm_qset, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | int hclge_dbg_read_cmd(struct hnae3_handle *handle, enum hnae3_dbg_cmd cmd, | ||||||
| 		       char *buf, int len) | 		       char *buf, int len) | ||||||
| { | { | ||||||
| 	struct hclge_vport *vport = hclge_get_vport(handle); | 	struct hclge_vport *vport = hclge_get_vport(handle); | ||||||
| 	struct hclge_dev *hdev = vport->back; | 	struct hclge_dev *hdev = vport->back; | ||||||
|  | 	u32 i; | ||||||
| 
 | 
 | ||||||
| 	if (strncmp(cmd_buf, HNAE3_DBG_TM_NODES, | 	for (i = 0; i < ARRAY_SIZE(hclge_dbg_cmd_func); i++) { | ||||||
| 		    strlen(HNAE3_DBG_TM_NODES)) == 0) | 		if (cmd == hclge_dbg_cmd_func[i].cmd) | ||||||
| 		return hclge_dbg_dump_tm_nodes(hdev, buf, len); | 			return hclge_dbg_cmd_func[i].dbg_dump(hdev, buf, len); | ||||||
| 	else if (strncmp(cmd_buf, HNAE3_DBG_TM_PRI, | 	} | ||||||
| 			 strlen(HNAE3_DBG_TM_PRI)) == 0) |  | ||||||
| 		return hclge_dbg_dump_tm_pri(hdev, buf, len); |  | ||||||
| 	else if (strncmp(cmd_buf, HNAE3_DBG_TM_QSET, |  | ||||||
| 			 strlen(HNAE3_DBG_TM_QSET)) == 0) |  | ||||||
| 		return hclge_dbg_dump_tm_qset(hdev, buf, len); |  | ||||||
| 
 | 
 | ||||||
|  | 	dev_err(&hdev->pdev->dev, "invalid command(%d)\n", cmd); | ||||||
| 	return -EINVAL; | 	return -EINVAL; | ||||||
| } | } | ||||||
|  | |||||||
| @ -83,6 +83,11 @@ struct hclge_dbg_reg_type_info { | |||||||
| 	struct hclge_dbg_reg_common_msg reg_msg; | 	struct hclge_dbg_reg_common_msg reg_msg; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | struct hclge_dbg_func { | ||||||
|  | 	enum hnae3_dbg_cmd cmd; | ||||||
|  | 	int (*dbg_dump)(struct hclge_dev *hdev, char *buf, int len); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| static const struct hclge_dbg_dfx_message hclge_dbg_bios_common_reg[] = { | static const struct hclge_dbg_dfx_message hclge_dbg_bios_common_reg[] = { | ||||||
| 	{false, "Reserved"}, | 	{false, "Reserved"}, | ||||||
| 	{true,	"BP_CPU_STATE"}, | 	{true,	"BP_CPU_STATE"}, | ||||||
|  | |||||||
| @ -1061,7 +1061,7 @@ int hclge_vport_start(struct hclge_vport *vport); | |||||||
| void hclge_vport_stop(struct hclge_vport *vport); | void hclge_vport_stop(struct hclge_vport *vport); | ||||||
| int hclge_set_vport_mtu(struct hclge_vport *vport, int new_mtu); | int hclge_set_vport_mtu(struct hclge_vport *vport, int new_mtu); | ||||||
| int hclge_dbg_run_cmd(struct hnae3_handle *handle, const char *cmd_buf); | int hclge_dbg_run_cmd(struct hnae3_handle *handle, const char *cmd_buf); | ||||||
| int hclge_dbg_read_cmd(struct hnae3_handle *handle, const char *cmd_buf, | int hclge_dbg_read_cmd(struct hnae3_handle *handle, enum hnae3_dbg_cmd cmd, | ||||||
| 		       char *buf, int len); | 		       char *buf, int len); | ||||||
| u16 hclge_covert_handle_qid_global(struct hnae3_handle *handle, u16 queue_id); | u16 hclge_covert_handle_qid_global(struct hnae3_handle *handle, u16 queue_id); | ||||||
| int hclge_notify_client(struct hclge_dev *hdev, | int hclge_notify_client(struct hclge_dev *hdev, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Yufeng Mo
						Yufeng Mo