aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/cminst44xx.c
Commit message (Expand)AuthorAge
* Patched in Tegra support.Jonathan Herman2013-01-17
* ARM: OMAP2/3: clockdomain/PRM/CM: move the low-level clockdomain functions in...Paul Walmsley2012-10-21
* ARM: OMAP4: clockdomain/CM code: Update supported transition modesJon Hunter2012-07-04
* ARM: OMAP2+: CM: increase the module disable timeoutPaul Walmsley2012-06-21
* ARM: OMAP4+: Add prm and cm base init function.R Sricharan2012-05-08
* ARM: OMAP2+: Move most of plat/io.h into local iomap.hTony Lindgren2012-02-24
* ARM: 7159/1: OMAP: Introduce local common.h filesTony Lindgren2011-11-17
* OMAP4: cm: Add two new APIs for modulemode controlBenoit Cousson2011-07-10
* OMAP: hwmod: Wait the idle status to be disabledBenoit Cousson2011-07-10
* OMAP4: hwmod: Replace CLKCTRL absolute address with offset macrosBenoit Cousson2011-07-10
* OMAP4: CM: Add CM accesor api for bitwise controlRajendra Nayak2011-02-25
* OMAP4: clockdomains: add OMAP4 PRCM data and OMAP4 supportPaul Walmsley2010-12-21
* OMAP4: PRCM: add OMAP4-specific accessor/mutator functionsPaul Walmsley2010-12-21
multipath.c?h=v2.6.31-rc5&id=a89ecb6a2ef732d04058d87801e2b6bd7e5c7089'>diffstats
path: root/net/ipv4/multipath.c
blob: 4e9ca7c76407da4d1ddfeb29ba5e80322effafda (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/* multipath.c: IPV4 multipath algorithm support.
 *
 * Copyright (C) 2004, 2005 Einar Lueck <elueck@de.ibm.com>
 * Copyright (C) 2005 David S. Miller <davem@davemloft.net>
 */

#include <linux/module.h>
#include <linux/errno.h>
#include <linux/netdevice.h>
#include <linux/spinlock.h>

#include <net/ip_mp_alg.h>

static DEFINE_SPINLOCK(alg_table_lock);
struct ip_mp_alg_ops *ip_mp_alg_table[IP_MP_ALG_MAX + 1];

int multipath_alg_register(struct ip_mp_alg_ops *ops, enum ip_mp_alg n)
{
	struct ip_mp_alg_ops **slot;
	int err;

	if (n < IP_MP_ALG_NONE || n > IP_MP_ALG_MAX ||
	    !ops->mp_alg_select_route)
		return -EINVAL;

	spin_lock(&alg_table_lock);
	slot = &ip_mp_alg_table[n];
	if (*slot != NULL) {
		err = -EBUSY;
	} else {
		*slot = ops;
		err = 0;
	}
	spin_unlock(&alg_table_lock);

	return err;
}
EXPORT_SYMBOL(multipath_alg_register);

void multipath_alg_unregister(struct ip_mp_alg_ops *ops, enum ip_mp_alg n)
{
	struct ip_mp_alg_ops **slot;

	if (n < IP_MP_ALG_NONE || n > IP_MP_ALG_MAX)
		return;

	spin_lock(&alg_table_lock);
	slot = &ip_mp_alg_table[n];
	if (*slot == ops)
		*slot = NULL;
	spin_unlock(&alg_table_lock);

	synchronize_net();
}
EXPORT_SYMBOL(multipath_alg_unregister);