mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-12 08:48:48 +00:00
b8ace0833f
The hardwall drain code was not properly implemented for tilegx, just tilepro, so you couldn't reliably restart an application that made use of the udn. In addition, the code was only applicable to the udn (user dynamic network). On tilegx there is a second user network that is available (the "idn"), and there is support for having I/O shims deliver user-level interrupts to applications ("ipi") which functions in a very similar way to the inter-core permissions used for udn/idn. So this change also generalizes the code from supporting just the udn to supports udn/idn/ipi on tilegx. By default we now use /dev/hardwall/{udn,idn,ipi} with separate minor numbers for the three devices. Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
62 lines
1.9 KiB
C
62 lines
1.9 KiB
C
/*
|
|
* 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 _ASM_TILE_HARDWALL_H
|
|
#define _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)
|
|
|
|
#ifdef __KERNEL__
|
|
/* /proc hooks for hardwall. */
|
|
struct proc_dir_entry;
|
|
#ifdef CONFIG_HARDWALL
|
|
void proc_tile_hardwall_init(struct proc_dir_entry *root);
|
|
int proc_pid_hardwall(struct task_struct *task, char *buffer);
|
|
#else
|
|
static inline void proc_tile_hardwall_init(struct proc_dir_entry *root) {}
|
|
#endif
|
|
#endif
|
|
|
|
#endif /* _ASM_TILE_HARDWALL_H */
|