Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
5159f8f6
Commit
5159f8f6
authored
Nov 16, 2015
by
Felix Lange
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
crypto/secp256k1: raise internal errors as recoverable Go panic
parent
1b29aed1
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
39 additions
and
0 deletions
+39
-0
panic_cb.go
crypto/secp256k1/panic_cb.go
+33
-0
secp256.go
crypto/secp256k1/secp256.go
+6
-0
No files found.
crypto/secp256k1/panic_cb.go
0 → 100644
View file @
5159f8f6
// Copyright 2015 The go-ethereum Authors
// This file is part of the go-ethereum library.
//
// The go-ethereum library is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// The go-ethereum library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
package
secp256k1
import
"C"
import
"unsafe"
// Callbacks for converting libsecp256k1 internal faults into
// recoverable Go panics.
//export secp256k1GoPanicIllegal
func
secp256k1GoPanicIllegal
(
msg
*
C
.
char
,
data
unsafe
.
Pointer
)
{
panic
(
"illegal argument: "
+
C
.
GoString
(
msg
))
}
//export secp256k1GoPanicError
func
secp256k1GoPanicError
(
msg
*
C
.
char
,
data
unsafe
.
Pointer
)
{
panic
(
"internal error: "
+
C
.
GoString
(
msg
))
}
crypto/secp256k1/secp256.go
View file @
5159f8f6
...
...
@@ -35,6 +35,10 @@ package secp256k1
#define NDEBUG
#include "./libsecp256k1/src/secp256k1.c"
#include "./libsecp256k1/src/modules/recovery/main_impl.h"
typedef void (*callbackFunc) (const char* msg, void* data);
extern void secp256k1GoPanicIllegal(const char* msg, void* data);
extern void secp256k1GoPanicError(const char* msg, void* data);
*/
import
"C"
...
...
@@ -61,6 +65,8 @@ var context *C.secp256k1_context
func
init
()
{
// around 20 ms on a modern CPU.
context
=
C
.
secp256k1_context_create
(
3
)
// SECP256K1_START_SIGN | SECP256K1_START_VERIFY
C
.
secp256k1_context_set_illegal_callback
(
context
,
C
.
callbackFunc
(
C
.
secp256k1GoPanicIllegal
),
nil
)
C
.
secp256k1_context_set_error_callback
(
context
,
C
.
callbackFunc
(
C
.
secp256k1GoPanicError
),
nil
)
}
var
(
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment