162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2015 Imagination Technologies 462306a36Sopenharmony_ci * Author: Paul Burton <paul.burton@mips.com> 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#include <asm/bcache.h> 862306a36Sopenharmony_ci#include <asm/debug.h> 962306a36Sopenharmony_ci#include <linux/uaccess.h> 1062306a36Sopenharmony_ci#include <linux/debugfs.h> 1162306a36Sopenharmony_ci#include <linux/init.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_cistatic ssize_t sc_prefetch_read(struct file *file, char __user *user_buf, 1462306a36Sopenharmony_ci size_t count, loff_t *ppos) 1562306a36Sopenharmony_ci{ 1662306a36Sopenharmony_ci bool enabled = bc_prefetch_is_enabled(); 1762306a36Sopenharmony_ci char buf[3]; 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci buf[0] = enabled ? 'Y' : 'N'; 2062306a36Sopenharmony_ci buf[1] = '\n'; 2162306a36Sopenharmony_ci buf[2] = 0; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci return simple_read_from_buffer(user_buf, count, ppos, buf, 2); 2462306a36Sopenharmony_ci} 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_cistatic ssize_t sc_prefetch_write(struct file *file, 2762306a36Sopenharmony_ci const char __user *user_buf, 2862306a36Sopenharmony_ci size_t count, loff_t *ppos) 2962306a36Sopenharmony_ci{ 3062306a36Sopenharmony_ci bool enabled; 3162306a36Sopenharmony_ci int err; 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci err = kstrtobool_from_user(user_buf, count, &enabled); 3462306a36Sopenharmony_ci if (err) 3562306a36Sopenharmony_ci return err; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci if (enabled) 3862306a36Sopenharmony_ci bc_prefetch_enable(); 3962306a36Sopenharmony_ci else 4062306a36Sopenharmony_ci bc_prefetch_disable(); 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci return count; 4362306a36Sopenharmony_ci} 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cistatic const struct file_operations sc_prefetch_fops = { 4662306a36Sopenharmony_ci .open = simple_open, 4762306a36Sopenharmony_ci .llseek = default_llseek, 4862306a36Sopenharmony_ci .read = sc_prefetch_read, 4962306a36Sopenharmony_ci .write = sc_prefetch_write, 5062306a36Sopenharmony_ci}; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_cistatic int __init sc_debugfs_init(void) 5362306a36Sopenharmony_ci{ 5462306a36Sopenharmony_ci struct dentry *dir; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci dir = debugfs_create_dir("l2cache", mips_debugfs_dir); 5762306a36Sopenharmony_ci debugfs_create_file("prefetch", S_IRUGO | S_IWUSR, dir, NULL, 5862306a36Sopenharmony_ci &sc_prefetch_fops); 5962306a36Sopenharmony_ci return 0; 6062306a36Sopenharmony_ci} 6162306a36Sopenharmony_cilate_initcall(sc_debugfs_init); 62