Commit ca03258b authored by Sukadev Bhattiprolu's avatar Sukadev Bhattiprolu Committed by Michael Ellerman

powerpc/vas: Create cpu to vas id mapping

Create a cpu to vasid mapping so callers can specify -1 instead of
trying to find a VAS id.

Changelog[v2]
	[Michael Ellerman] Use per-cpu variables to simplify code.
Signed-off-by: default avatarSukadev Bhattiprolu <sukadev@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 6fccac16
...@@ -18,15 +18,18 @@ ...@@ -18,15 +18,18 @@
#include <linux/of_platform.h> #include <linux/of_platform.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <linux/of.h> #include <linux/of.h>
#include <asm/prom.h>
#include "vas.h" #include "vas.h"
static DEFINE_MUTEX(vas_mutex); static DEFINE_MUTEX(vas_mutex);
static LIST_HEAD(vas_instances); static LIST_HEAD(vas_instances);
static DEFINE_PER_CPU(int, cpu_vas_id);
static int init_vas_instance(struct platform_device *pdev) static int init_vas_instance(struct platform_device *pdev)
{ {
int rc, vasid; int rc, cpu, vasid;
struct resource *res; struct resource *res;
struct vas_instance *vinst; struct vas_instance *vinst;
struct device_node *dn = pdev->dev.of_node; struct device_node *dn = pdev->dev.of_node;
...@@ -74,6 +77,11 @@ static int init_vas_instance(struct platform_device *pdev) ...@@ -74,6 +77,11 @@ static int init_vas_instance(struct platform_device *pdev)
"paste_win_id_shift 0x%llx\n", pdev->name, vasid, "paste_win_id_shift 0x%llx\n", pdev->name, vasid,
vinst->paste_base_addr, vinst->paste_win_id_shift); vinst->paste_base_addr, vinst->paste_win_id_shift);
for_each_possible_cpu(cpu) {
if (cpu_to_chip_id(cpu) == of_get_ibm_chip_id(dn))
per_cpu(cpu_vas_id, cpu) = vasid;
}
mutex_lock(&vas_mutex); mutex_lock(&vas_mutex);
list_add(&vinst->node, &vas_instances); list_add(&vinst->node, &vas_instances);
mutex_unlock(&vas_mutex); mutex_unlock(&vas_mutex);
...@@ -98,6 +106,10 @@ struct vas_instance *find_vas_instance(int vasid) ...@@ -98,6 +106,10 @@ struct vas_instance *find_vas_instance(int vasid)
struct vas_instance *vinst; struct vas_instance *vinst;
mutex_lock(&vas_mutex); mutex_lock(&vas_mutex);
if (vasid == -1)
vasid = per_cpu(cpu_vas_id, smp_processor_id());
list_for_each(ent, &vas_instances) { list_for_each(ent, &vas_instances) {
vinst = list_entry(ent, struct vas_instance, node); vinst = list_entry(ent, struct vas_instance, node);
if (vinst->vas_id == vasid) { if (vinst->vas_id == vasid) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment