[rtems-libbsd commit] ZONE(9): Disable UMA_ZONE_NUMA

Sebastian Huber sebh at rtems.org
Tue Oct 23 11:27:43 UTC 2018


Module:    rtems-libbsd
Branch:    master
Commit:    dbb24072dbfffc2ff1246af441033ea7f5525215
Changeset: http://git.rtems.org/rtems-libbsd/commit/?id=dbb24072dbfffc2ff1246af441033ea7f5525215

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Tue Oct 23 12:11:54 2018 +0200

ZONE(9): Disable UMA_ZONE_NUMA

There is no NUMA support in RTEMS currently.

---

 freebsd/sys/vm/uma.h      |  2 ++
 freebsd/sys/vm/uma_core.c | 27 +++++++++++++++++++++++++--
 freebsd/sys/vm/uma_int.h  |  4 ++++
 3 files changed, 31 insertions(+), 2 deletions(-)

diff --git a/freebsd/sys/vm/uma.h b/freebsd/sys/vm/uma.h
index 3ab6556..f05f686 100644
--- a/freebsd/sys/vm/uma.h
+++ b/freebsd/sys/vm/uma.h
@@ -281,10 +281,12 @@ uma_zone_t uma_zcache_create(char *name, int size, uma_ctor ctor, uma_dtor dtor,
 #define	UMA_ZONE_PCPU		0x8000	/*
 					 * Allocates mp_maxid + 1 slabs of PAGE_SIZE
 					 */
+#ifndef __rtems__
 #define	UMA_ZONE_NUMA		0x10000	/*
 					 * NUMA aware Zone.  Implements a best
 					 * effort first-touch policy.
 					 */
+#endif /* __rtems__ */
 #define	UMA_ZONE_NOBUCKETCACHE	0x20000	/*
 					 * Don't cache full buckets.  Limit
 					 * UMA to per-cpu state.
diff --git a/freebsd/sys/vm/uma_core.c b/freebsd/sys/vm/uma_core.c
index 0f4bbb3..2a1e1b0 100644
--- a/freebsd/sys/vm/uma_core.c
+++ b/freebsd/sys/vm/uma_core.c
@@ -404,7 +404,11 @@ bucket_init(void)
 		size += sizeof(void *) * ubz->ubz_entries;
 		ubz->ubz_zone = uma_zcreate(ubz->ubz_name, size,
 		    NULL, NULL, NULL, NULL, UMA_ALIGN_PTR,
+#ifndef __rtems__
 		    UMA_ZONE_MTXCLASS | UMA_ZFLAG_BUCKET | UMA_ZONE_NUMA);
+#else /* __rtems__ */
+		    UMA_ZONE_MTXCLASS | UMA_ZFLAG_BUCKET);
+#endif /* __rtems__ */
 	}
 }
 
@@ -819,9 +823,11 @@ cache_drain_safe_cpu(uma_zone_t zone)
 	b1 = b2 = NULL;
 	ZONE_LOCK(zone);
 	critical_enter();
+#ifndef __rtems__
 	if (zone->uz_flags & UMA_ZONE_NUMA)
 		domain = PCPU_GET(domain);
 	else
+#endif /* __rtems__ */
 		domain = 0;
 	cache = &zone->uz_cpu[curcpu];
 	if (cache->uc_allocbucket) {
@@ -1787,8 +1793,10 @@ zone_ctor(void *mem, int size, void *udata, int flags)
 	zone->uz_count_min = 0;
 	zone->uz_flags = 0;
 	zone->uz_warning = NULL;
+#ifndef __rtems__
 	/* The domain structures follow the cpu structures. */
 	zone->uz_domain = (struct uma_zone_domain *)&zone->uz_cpu[mp_ncpus];
+#endif /* __rtems__ */
 	timevalclear(&zone->uz_ratecheck);
 	keg = arg->keg;
 
@@ -2072,8 +2080,7 @@ uma_startup(void *mem, int npages)
 	ksize = sizeof(struct uma_keg) +
 	    (sizeof(struct uma_domain) * vm_ndomains);
 	zsize = sizeof(struct uma_zone) +
-	    (sizeof(struct uma_cache) * (mp_maxid + 1)) +
-	    (sizeof(struct uma_zone_domain) * vm_ndomains);
+	    (sizeof(struct uma_cache) * (mp_maxid + 1));
 	size = 2 * roundup(zsize, CACHE_LINE_SIZE) +
 	    roundup(ksize, CACHE_LINE_SIZE);
 #endif /* __rtems__ */
@@ -2603,9 +2610,11 @@ zalloc_start:
 	if (bucket != NULL)
 		bucket_free(zone, bucket, udata);
 
+#ifndef __rtems__
 	if (zone->uz_flags & UMA_ZONE_NUMA)
 		domain = PCPU_GET(domain);
 	else
+#endif /* __rtems__ */
 		domain = UMA_ANYDOMAIN;
 
 	/* Short-circuit for zones without buckets and low memory. */
@@ -2682,9 +2691,13 @@ zalloc_start:
 		 * initialized bucket to make this less likely or claim
 		 * the memory directly.
 		 */
+#ifndef __rtems__
 		if (cache->uc_allocbucket != NULL ||
 		    (zone->uz_flags & UMA_ZONE_NUMA &&
 		    domain != PCPU_GET(domain)))
+#else /* __rtems__ */
+		if (cache->uc_allocbucket != NULL)
+#endif /* __rtems__ */
 			LIST_INSERT_HEAD(&zdom->uzd_buckets, bucket, ub_link);
 		else
 			cache->uc_allocbucket = bucket;
@@ -3162,7 +3175,11 @@ uma_zfree_arg(uma_zone_t zone, void *item, void *udata)
 	uma_cache_t cache;
 	uma_bucket_t bucket;
 	uma_zone_domain_t zdom;
+#ifndef __rtems__
 	int cpu, domain, lockfail;
+#else /* __rtems__ */
+	int cpu, lockfail;
+#endif /* __rtems__ */
 #ifdef INVARIANTS
 	bool skipdbg;
 #endif
@@ -3279,10 +3296,12 @@ zfree_start:
 	/* We are no longer associated with this CPU. */
 	critical_exit();
 
+#ifndef __rtems__
 	if ((zone->uz_flags & UMA_ZONE_NUMA) != 0)
 		domain = PCPU_GET(domain);
 	else 
 		domain = 0;
+#endif /* __rtems__ */
 	zdom = &zone->uz_domain[0];
 
 	/* Can we throw this on the zone full list? */
@@ -3317,9 +3336,13 @@ zfree_start:
 		critical_enter();
 		cpu = curcpu;
 		cache = &zone->uz_cpu[cpu];
+#ifndef __rtems__
 		if (cache->uc_freebucket == NULL &&
 		    ((zone->uz_flags & UMA_ZONE_NUMA) == 0 ||
 		    domain == PCPU_GET(domain))) {
+#else /* __rtems__ */
+		if (cache->uc_freebucket == NULL) {
+#endif /* __rtems__ */
 			cache->uc_freebucket = bucket;
 			goto zfree_start;
 		}
diff --git a/freebsd/sys/vm/uma_int.h b/freebsd/sys/vm/uma_int.h
index 5f787df..ff63809 100644
--- a/freebsd/sys/vm/uma_int.h
+++ b/freebsd/sys/vm/uma_int.h
@@ -321,7 +321,11 @@ struct uma_zone {
 	/* Offset 0, used in alloc/free fast/medium fast path and const. */
 	struct mtx	*uz_lockptr;
 	const char	*uz_name;	/* Text name of the zone */
+#ifndef __rtems__
 	struct uma_zone_domain	*uz_domain;	/* per-domain buckets */
+#else /* __rtems__ */
+	struct uma_zone_domain	uz_domain[1];	/* per-domain buckets */
+#endif /* __rtems__ */
 	uint32_t	uz_flags;	/* Flags inherited from kegs */
 	uint32_t	uz_size;	/* Size inherited from kegs */
 	uma_ctor	uz_ctor;	/* Constructor for each allocation */



More information about the vc mailing list