| /* |
| * Copyright 2010 Tilera Corporation. All Rights Reserved. |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License |
| * as published by the Free Software Foundation, version 2. |
| * |
| * This program is distributed in the hope that it will be useful, but |
| * WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or |
| * NON INFRINGEMENT. See the GNU General Public License for |
| * more details. |
| * |
| * Provide methods for access control of per-cpu resources like |
| * UDN, IDN, or IPI. |
| */ |
| |
| #ifndef _UAPI_ASM_TILE_HARDWALL_H |
| #define _UAPI_ASM_TILE_HARDWALL_H |
| |
| #include <arch/chip.h> |
| #include <linux/ioctl.h> |
| |
| #define HARDWALL_IOCTL_BASE 0xa2 |
| |
| /* |
| * The HARDWALL_CREATE() ioctl is a macro with a "size" argument. |
| * The resulting ioctl value is passed to the kernel in conjunction |
| * with a pointer to a standard kernel bitmask of cpus. |
| * For network resources (UDN or IDN) the bitmask must physically |
| * represent a rectangular configuration on the chip. |
| * The "size" is the number of bytes of cpu mask data. |
| */ |
| #define _HARDWALL_CREATE 1 |
| #define HARDWALL_CREATE(size) \ |
| _IOC(_IOC_READ, HARDWALL_IOCTL_BASE, _HARDWALL_CREATE, (size)) |
| |
| #define _HARDWALL_ACTIVATE 2 |
| #define HARDWALL_ACTIVATE \ |
| _IO(HARDWALL_IOCTL_BASE, _HARDWALL_ACTIVATE) |
| |
| #define _HARDWALL_DEACTIVATE 3 |
| #define HARDWALL_DEACTIVATE \ |
| _IO(HARDWALL_IOCTL_BASE, _HARDWALL_DEACTIVATE) |
| |
| #define _HARDWALL_GET_ID 4 |
| #define HARDWALL_GET_ID \ |
| _IO(HARDWALL_IOCTL_BASE, _HARDWALL_GET_ID) |
| |
| |
| #endif /* _UAPI_ASM_TILE_HARDWALL_H */ |