mirror of
https://github.com/golang/go.git
synced 2025-05-05 15:43:04 +00:00
container/intsets: use fast popcount with gccgo
Use the compiler intrinsic __builtin_popcount. Change-Id: I58286fbcf66d1068390ea9caff2f98b8fe244c2d Reviewed-on: https://go-review.googlesource.com/16831 Reviewed-by: Andrew Gerrand <adg@golang.org>
This commit is contained in:
parent
3dedf801dd
commit
d94e6fe0fd
9
container/intsets/popcnt_gccgo.go
Normal file
9
container/intsets/popcnt_gccgo.go
Normal file
@ -0,0 +1,9 @@
|
||||
// Copyright 2015 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.
|
||||
|
||||
// +build gccgo
|
||||
|
||||
package intsets
|
||||
|
||||
func popcount(x word) int
|
19
container/intsets/popcnt_gccgo_c.c
Normal file
19
container/intsets/popcnt_gccgo_c.c
Normal file
@ -0,0 +1,19 @@
|
||||
// Copyright 2015 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.
|
||||
|
||||
// +build gccgo
|
||||
|
||||
#include <errno.h>
|
||||
#include <stdint.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define _STRINGIFY2_(x) #x
|
||||
#define _STRINGIFY_(x) _STRINGIFY2_(x)
|
||||
#define GOSYM_PREFIX _STRINGIFY_(__USER_LABEL_PREFIX__)
|
||||
|
||||
extern intptr_t popcount(uintptr_t x) __asm__(GOSYM_PREFIX GOPKGPATH ".popcount");
|
||||
|
||||
intptr_t popcount(uintptr_t x) {
|
||||
return __builtin_popcountl((unsigned long)(x));
|
||||
}
|
@ -2,7 +2,8 @@
|
||||
// Use of this source code is governed by a BSD-style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
// +build !amd64 appengine gccgo
|
||||
// +build !amd64 appengine
|
||||
// +build !gccgo
|
||||
|
||||
package intsets
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user