blob: 47514a58d68559a86fef6a0b7de1fa63c3fbc126 [file] [log] [blame]
Chris Metcalf9f9c0382010-06-25 17:00:56 -04001/*
2 * Copyright 2010 Tilera Corporation. All Rights Reserved.
3 *
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation, version 2.
7 *
8 * This program is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or
11 * NON INFRINGEMENT. See the GNU General Public License for
12 * more details.
13 *
Chris Metcalfb8ace082012-03-30 16:01:48 -040014 * Provide methods for access control of per-cpu resources like
15 * UDN, IDN, or IPI.
Chris Metcalf9f9c0382010-06-25 17:00:56 -040016 */
17
18#ifndef _ASM_TILE_HARDWALL_H
19#define _ASM_TILE_HARDWALL_H
20
Chris Metcalfb8ace082012-03-30 16:01:48 -040021#include <arch/chip.h>
Chris Metcalf9f9c0382010-06-25 17:00:56 -040022#include <linux/ioctl.h>
23
24#define HARDWALL_IOCTL_BASE 0xa2
25
26/*
27 * The HARDWALL_CREATE() ioctl is a macro with a "size" argument.
28 * The resulting ioctl value is passed to the kernel in conjunction
Chris Metcalfb8ace082012-03-30 16:01:48 -040029 * with a pointer to a standard kernel bitmask of cpus.
30 * For network resources (UDN or IDN) the bitmask must physically
31 * represent a rectangular configuration on the chip.
Chris Metcalf9f9c0382010-06-25 17:00:56 -040032 * The "size" is the number of bytes of cpu mask data.
33 */
34#define _HARDWALL_CREATE 1
35#define HARDWALL_CREATE(size) \
36 _IOC(_IOC_READ, HARDWALL_IOCTL_BASE, _HARDWALL_CREATE, (size))
37
38#define _HARDWALL_ACTIVATE 2
39#define HARDWALL_ACTIVATE \
40 _IO(HARDWALL_IOCTL_BASE, _HARDWALL_ACTIVATE)
41
42#define _HARDWALL_DEACTIVATE 3
43#define HARDWALL_DEACTIVATE \
44 _IO(HARDWALL_IOCTL_BASE, _HARDWALL_DEACTIVATE)
45
Chris Metcalff133ecc2011-05-26 12:40:09 -040046#define _HARDWALL_GET_ID 4
47#define HARDWALL_GET_ID \
48 _IO(HARDWALL_IOCTL_BASE, _HARDWALL_GET_ID)
49
Chris Metcalfb8ace082012-03-30 16:01:48 -040050#ifdef __KERNEL__
Chris Metcalff133ecc2011-05-26 12:40:09 -040051/* /proc hooks for hardwall. */
52struct proc_dir_entry;
53#ifdef CONFIG_HARDWALL
54void proc_tile_hardwall_init(struct proc_dir_entry *root);
55int proc_pid_hardwall(struct task_struct *task, char *buffer);
56#else
57static inline void proc_tile_hardwall_init(struct proc_dir_entry *root) {}
58#endif
Chris Metcalf9f9c0382010-06-25 17:00:56 -040059#endif
60
61#endif /* _ASM_TILE_HARDWALL_H */