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
|
// Use of this source code is governed by a BSD-style
|
||||||
// license that can be found in the LICENSE file.
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
// +build !amd64 appengine gccgo
|
// +build !amd64 appengine
|
||||||
|
// +build !gccgo
|
||||||
|
|
||||||
package intsets
|
package intsets
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user