162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * debugfs routines supporting the Power 7+ Nest Accelerators driver 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2011-2012 International Business Machines Inc. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Author: Kent Yoder <yoder1@us.ibm.com> 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include <linux/device.h> 1162306a36Sopenharmony_ci#include <linux/kobject.h> 1262306a36Sopenharmony_ci#include <linux/string.h> 1362306a36Sopenharmony_ci#include <linux/debugfs.h> 1462306a36Sopenharmony_ci#include <linux/module.h> 1562306a36Sopenharmony_ci#include <linux/init.h> 1662306a36Sopenharmony_ci#include <linux/crypto.h> 1762306a36Sopenharmony_ci#include <crypto/hash.h> 1862306a36Sopenharmony_ci#include <asm/vio.h> 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci#include "nx_csbcpb.h" 2162306a36Sopenharmony_ci#include "nx.h" 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci#ifdef CONFIG_DEBUG_FS 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci/* 2662306a36Sopenharmony_ci * debugfs 2762306a36Sopenharmony_ci * 2862306a36Sopenharmony_ci * For documentation on these attributes, please see: 2962306a36Sopenharmony_ci * 3062306a36Sopenharmony_ci * Documentation/ABI/testing/debugfs-pfo-nx-crypto 3162306a36Sopenharmony_ci */ 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_civoid nx_debugfs_init(struct nx_crypto_driver *drv) 3462306a36Sopenharmony_ci{ 3562306a36Sopenharmony_ci struct dentry *root; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci root = debugfs_create_dir(NX_NAME, NULL); 3862306a36Sopenharmony_ci drv->dfs_root = root; 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci debugfs_create_u32("aes_ops", S_IRUSR | S_IRGRP | S_IROTH, 4162306a36Sopenharmony_ci root, &drv->stats.aes_ops.counter); 4262306a36Sopenharmony_ci debugfs_create_u32("sha256_ops", S_IRUSR | S_IRGRP | S_IROTH, 4362306a36Sopenharmony_ci root, &drv->stats.sha256_ops.counter); 4462306a36Sopenharmony_ci debugfs_create_u32("sha512_ops", S_IRUSR | S_IRGRP | S_IROTH, 4562306a36Sopenharmony_ci root, &drv->stats.sha512_ops.counter); 4662306a36Sopenharmony_ci debugfs_create_u64("aes_bytes", S_IRUSR | S_IRGRP | S_IROTH, 4762306a36Sopenharmony_ci root, &drv->stats.aes_bytes.counter); 4862306a36Sopenharmony_ci debugfs_create_u64("sha256_bytes", S_IRUSR | S_IRGRP | S_IROTH, 4962306a36Sopenharmony_ci root, &drv->stats.sha256_bytes.counter); 5062306a36Sopenharmony_ci debugfs_create_u64("sha512_bytes", S_IRUSR | S_IRGRP | S_IROTH, 5162306a36Sopenharmony_ci root, &drv->stats.sha512_bytes.counter); 5262306a36Sopenharmony_ci debugfs_create_u32("errors", S_IRUSR | S_IRGRP | S_IROTH, 5362306a36Sopenharmony_ci root, &drv->stats.errors.counter); 5462306a36Sopenharmony_ci debugfs_create_u32("last_error", S_IRUSR | S_IRGRP | S_IROTH, 5562306a36Sopenharmony_ci root, &drv->stats.last_error.counter); 5662306a36Sopenharmony_ci debugfs_create_u32("last_error_pid", S_IRUSR | S_IRGRP | S_IROTH, 5762306a36Sopenharmony_ci root, &drv->stats.last_error_pid.counter); 5862306a36Sopenharmony_ci} 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_civoid 6162306a36Sopenharmony_cinx_debugfs_fini(struct nx_crypto_driver *drv) 6262306a36Sopenharmony_ci{ 6362306a36Sopenharmony_ci debugfs_remove_recursive(drv->dfs_root); 6462306a36Sopenharmony_ci} 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci#endif 67