1*64d85cc9SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only 2175e0e23SKent Yoder /** 3175e0e23SKent Yoder * debugfs routines supporting the Power 7+ Nest Accelerators driver 4175e0e23SKent Yoder * 5175e0e23SKent Yoder * Copyright (C) 2011-2012 International Business Machines Inc. 6175e0e23SKent Yoder * 7175e0e23SKent Yoder * Author: Kent Yoder <yoder1@us.ibm.com> 8175e0e23SKent Yoder */ 9175e0e23SKent Yoder 10175e0e23SKent Yoder #include <linux/device.h> 11175e0e23SKent Yoder #include <linux/kobject.h> 12175e0e23SKent Yoder #include <linux/string.h> 13175e0e23SKent Yoder #include <linux/debugfs.h> 14175e0e23SKent Yoder #include <linux/module.h> 15175e0e23SKent Yoder #include <linux/init.h> 16175e0e23SKent Yoder #include <linux/crypto.h> 17175e0e23SKent Yoder #include <crypto/hash.h> 18175e0e23SKent Yoder #include <asm/vio.h> 19175e0e23SKent Yoder 20175e0e23SKent Yoder #include "nx_csbcpb.h" 21175e0e23SKent Yoder #include "nx.h" 22175e0e23SKent Yoder 23175e0e23SKent Yoder #ifdef CONFIG_DEBUG_FS 24175e0e23SKent Yoder 25175e0e23SKent Yoder /* 26175e0e23SKent Yoder * debugfs 27175e0e23SKent Yoder * 28175e0e23SKent Yoder * For documentation on these attributes, please see: 29175e0e23SKent Yoder * 30175e0e23SKent Yoder * Documentation/ABI/testing/debugfs-pfo-nx-crypto 31175e0e23SKent Yoder */ 32175e0e23SKent Yoder 33175e0e23SKent Yoder int nx_debugfs_init(struct nx_crypto_driver *drv) 34175e0e23SKent Yoder { 35175e0e23SKent Yoder struct nx_debugfs *dfs = &drv->dfs; 36175e0e23SKent Yoder 37175e0e23SKent Yoder dfs->dfs_root = debugfs_create_dir(NX_NAME, NULL); 38175e0e23SKent Yoder 39175e0e23SKent Yoder dfs->dfs_aes_ops = 40175e0e23SKent Yoder debugfs_create_u32("aes_ops", 41175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 42175e0e23SKent Yoder dfs->dfs_root, (u32 *)&drv->stats.aes_ops); 43175e0e23SKent Yoder dfs->dfs_sha256_ops = 44175e0e23SKent Yoder debugfs_create_u32("sha256_ops", 45175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 46175e0e23SKent Yoder dfs->dfs_root, 47175e0e23SKent Yoder (u32 *)&drv->stats.sha256_ops); 48175e0e23SKent Yoder dfs->dfs_sha512_ops = 49175e0e23SKent Yoder debugfs_create_u32("sha512_ops", 50175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 51175e0e23SKent Yoder dfs->dfs_root, 52175e0e23SKent Yoder (u32 *)&drv->stats.sha512_ops); 53175e0e23SKent Yoder dfs->dfs_aes_bytes = 54175e0e23SKent Yoder debugfs_create_u64("aes_bytes", 55175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 56175e0e23SKent Yoder dfs->dfs_root, 57175e0e23SKent Yoder (u64 *)&drv->stats.aes_bytes); 58175e0e23SKent Yoder dfs->dfs_sha256_bytes = 59175e0e23SKent Yoder debugfs_create_u64("sha256_bytes", 60175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 61175e0e23SKent Yoder dfs->dfs_root, 62175e0e23SKent Yoder (u64 *)&drv->stats.sha256_bytes); 63175e0e23SKent Yoder dfs->dfs_sha512_bytes = 64175e0e23SKent Yoder debugfs_create_u64("sha512_bytes", 65175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 66175e0e23SKent Yoder dfs->dfs_root, 67175e0e23SKent Yoder (u64 *)&drv->stats.sha512_bytes); 68175e0e23SKent Yoder dfs->dfs_errors = 69175e0e23SKent Yoder debugfs_create_u32("errors", 70175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 71175e0e23SKent Yoder dfs->dfs_root, (u32 *)&drv->stats.errors); 72175e0e23SKent Yoder dfs->dfs_last_error = 73175e0e23SKent Yoder debugfs_create_u32("last_error", 74175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 75175e0e23SKent Yoder dfs->dfs_root, 76175e0e23SKent Yoder (u32 *)&drv->stats.last_error); 77175e0e23SKent Yoder dfs->dfs_last_error_pid = 78175e0e23SKent Yoder debugfs_create_u32("last_error_pid", 79175e0e23SKent Yoder S_IRUSR | S_IRGRP | S_IROTH, 80175e0e23SKent Yoder dfs->dfs_root, 81175e0e23SKent Yoder (u32 *)&drv->stats.last_error_pid); 82175e0e23SKent Yoder return 0; 83175e0e23SKent Yoder } 84175e0e23SKent Yoder 85175e0e23SKent Yoder void 86175e0e23SKent Yoder nx_debugfs_fini(struct nx_crypto_driver *drv) 87175e0e23SKent Yoder { 88175e0e23SKent Yoder debugfs_remove_recursive(drv->dfs.dfs_root); 89175e0e23SKent Yoder } 90175e0e23SKent Yoder 91175e0e23SKent Yoder #endif 92