Parcourir la source

libwg-go: more efficient and safer string passing

It was unclear when the Go string was actually freed.

Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
master
Jason A. Donenfeld il y a 6 ans
Parent
révision
dea60e13c0
2 fichiers modifiés avec 7 ajouts et 10 suppressions
  1. +2
    -2
      app/tools/libwg-go/src/git.zx2c4.com/wireguard-go/api-android.go
  2. +5
    -8
      app/tools/libwg-go/src/git.zx2c4.com/wireguard-go/jni.c

+ 2
- 2
app/tools/libwg-go/src/git.zx2c4.com/wireguard-go/api-android.go Voir le fichier

@@ -161,8 +161,8 @@ func wgGetSocketV6(tunnelHandle int32) int32 {
}

//export wgVersion
func wgVersion() string {
return WireGuardGoVersion
func wgVersion() *C.char {
return C.CString(WireGuardGoVersion)
}

func main() {}

+ 5
- 8
app/tools/libwg-go/src/git.zx2c4.com/wireguard-go/jni.c Voir le fichier

@@ -12,7 +12,7 @@ extern int wgTurnOn(struct go_string ifname, int tun_fd, struct go_string settin
extern void wgTurnOff(int handle);
extern int wgGetSocketV4(int handle);
extern int wgGetSocketV6(int handle);
extern struct go_string wgVersion();
extern char *wgVersion();

JNIEXPORT jint JNICALL Java_com_wireguard_android_backend_GoBackend_wgTurnOn(JNIEnv *env, jclass c, jstring ifname, jint tun_fd, jstring settings)
{
@@ -50,13 +50,10 @@ JNIEXPORT jint JNICALL Java_com_wireguard_android_backend_GoBackend_wgGetSocketV
JNIEXPORT jstring JNICALL Java_com_wireguard_android_backend_GoBackend_wgVersion(JNIEnv *env, jclass c)
{
jstring ret;
struct go_string s = wgVersion();
char *cstr = malloc(s.n + 1);
if (!cstr)
char *version = wgVersion();
if (!version)
return NULL;
memcpy(cstr, s.str, s.n);
cstr[s.n] = '\0';
ret = (*env)->NewStringUTF(env, cstr);
free(cstr);
ret = (*env)->NewStringUTF(env, version);
free(version);
return ret;
}

Chargement…
Annuler
Enregistrer