| /* | 
 |  * 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 the HARDWALL_FILE for accessing the UDN. | 
 |  */ | 
 |  | 
 | #ifndef _ASM_TILE_HARDWALL_H | 
 | #define _ASM_TILE_HARDWALL_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 little-endian bitmask of cpus, which must be | 
 |  * physically in 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) | 
 |  | 
 | #ifndef __KERNEL__ | 
 |  | 
 | /* This is the canonical name expected by userspace. */ | 
 | #define HARDWALL_FILE "/dev/hardwall" | 
 |  | 
 | #else | 
 |  | 
 | /* Hook for /proc/tile/hardwall. */ | 
 | struct seq_file; | 
 | int proc_tile_hardwall_show(struct seq_file *sf, void *v); | 
 |  | 
 | #endif | 
 |  | 
 | #endif /* _ASM_TILE_HARDWALL_H */ |