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