summaryrefslogtreecommitdiff
path: root/libgo
diff options
context:
space:
mode:
authorian <ian@138bc75d-0d04-0410-961f-82ee72b054a4>2011-05-06 20:06:29 +0000
committerian <ian@138bc75d-0d04-0410-961f-82ee72b054a4>2011-05-06 20:06:29 +0000
commit670062dbabd0825f03f6e9ad01881968c40b7356 (patch)
treea04353390cbd4dbceb299c20d4a3c6ae273157b8 /libgo
parent69777e5df0f78b42768fb6053aa1ebbc3661c210 (diff)
downloadgcc-670062dbabd0825f03f6e9ad01881968c40b7356.tar.gz
More uses of backend interface for types.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@173507 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libgo')
-rw-r--r--libgo/runtime/channel.h3
-rw-r--r--libgo/runtime/go-map-index.c6
-rw-r--r--libgo/runtime/go-map-len.c2
-rw-r--r--libgo/runtime/go-map-range.c2
-rw-r--r--libgo/runtime/go-new-map.c4
-rw-r--r--libgo/runtime/map.h11
6 files changed, 16 insertions, 12 deletions
diff --git a/libgo/runtime/channel.h b/libgo/runtime/channel.h
index ac791746e17..9dcaf7fcdbb 100644
--- a/libgo/runtime/channel.h
+++ b/libgo/runtime/channel.h
@@ -74,6 +74,9 @@ struct __go_channel
uint64_t data[];
};
+/* Try to link up with the structure generated by the frontend. */
+typedef struct __go_channel __go_channel;
+
/* The mutex used to control access to the value pointed to by the
__go_channel_select selected field. No additional mutexes may be
acquired while this mutex is held. */
diff --git a/libgo/runtime/go-map-index.c b/libgo/runtime/go-map-index.c
index 1561c97a6e2..02a0f73f224 100644
--- a/libgo/runtime/go-map-index.c
+++ b/libgo/runtime/go-map-index.c
@@ -21,11 +21,11 @@ __go_map_rehash (struct __go_map *map)
size_t key_offset;
size_t key_size;
size_t (*hashfn) (const void *, size_t);
- size_t old_bucket_count;
+ uintptr_t old_bucket_count;
void **old_buckets;
- size_t new_bucket_count;
+ uintptr_t new_bucket_count;
void **new_buckets;
- size_t i;
+ uintptr_t i;
descriptor = map->__descriptor;
diff --git a/libgo/runtime/go-map-len.c b/libgo/runtime/go-map-len.c
index 01df5b41c6c..a8922b9f007 100644
--- a/libgo/runtime/go-map-len.c
+++ b/libgo/runtime/go-map-len.c
@@ -18,6 +18,6 @@ __go_map_len (struct __go_map *map)
{
if (map == NULL)
return 0;
- __go_assert (map->__element_count == (size_t) (int) map->__element_count);
+ __go_assert (map->__element_count == (uintptr_t) (int) map->__element_count);
return map->__element_count;
}
diff --git a/libgo/runtime/go-map-range.c b/libgo/runtime/go-map-range.c
index 364cda9b690..54444bc2104 100644
--- a/libgo/runtime/go-map-range.c
+++ b/libgo/runtime/go-map-range.c
@@ -34,7 +34,7 @@ __go_mapiternext (struct __go_hash_iter *it)
if (entry == NULL)
{
const struct __go_map *map;
- size_t bucket;
+ uintptr_t bucket;
map = it->map;
bucket = it->bucket;
diff --git a/libgo/runtime/go-new-map.c b/libgo/runtime/go-new-map.c
index 73e8d7dfe79..3a471299b22 100644
--- a/libgo/runtime/go-new-map.c
+++ b/libgo/runtime/go-new-map.c
@@ -73,8 +73,8 @@ static const unsigned long prime_list[] = /* 256 + 1 or 256 + 48 + 1 */
/* Return the next number from PRIME_LIST >= N. */
-unsigned long
-__go_map_next_prime (unsigned long n)
+uintptr_t
+__go_map_next_prime (uintptr_t n)
{
size_t low;
size_t high;
diff --git a/libgo/runtime/map.h b/libgo/runtime/map.h
index 9c3fda263a0..40c31f82315 100644
--- a/libgo/runtime/map.h
+++ b/libgo/runtime/map.h
@@ -1,10 +1,11 @@
/* map.h -- the map type for Go.
- Copyright 2009, 2010 The Go Authors. All rights reserved.
+ Copyright 2009 The Go Authors. All rights reserved.
Use of this source code is governed by a BSD-style
license that can be found in the LICENSE file. */
#include <stddef.h>
+#include <stdint.h>
#include "go-type.h"
@@ -38,10 +39,10 @@ struct __go_map
const struct __go_map_descriptor *__descriptor;
/* The number of elements in the hash table. */
- size_t __element_count;
+ uintptr_t __element_count;
/* The number of entries in the __buckets array. */
- size_t __bucket_count;
+ uintptr_t __bucket_count;
/* Each bucket is a pointer to a linked list of map entries. */
void **__buckets;
@@ -64,13 +65,13 @@ struct __go_hash_iter
all the entries in the current bucket. */
const void *next_entry;
/* The bucket index of the current and next entry. */
- size_t bucket;
+ uintptr_t bucket;
};
extern struct __go_map *__go_new_map (const struct __go_map_descriptor *,
uintptr_t);
-extern unsigned long __go_map_next_prime (unsigned long);
+extern uintptr_t __go_map_next_prime (uintptr_t);
extern void *__go_map_index (struct __go_map *, const void *, _Bool);