Skip site navigation (1)Skip section navigation (2)
Date:      Tue,  4 Nov 2008 23:02:08 +0100 (CET)
From:      Guido Falsi <mad@madpilot.net>
To:        FreeBSD-gnats-submit@FreeBSD.org
Subject:   ports/128589: [maintainer-update] comms/gnokii update to 0.6.27
Message-ID:  <20081104220208.5ABB1130C39@megatron.madpilot.net>
Resent-Message-ID: <200811042210.mA4MA2Ws025135@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         128589
>Category:       ports
>Synopsis:       [maintainer-update] comms/gnokii update to 0.6.27
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          maintainer-update
>Submitter-Id:   current-users
>Arrival-Date:   Tue Nov 04 22:10:02 UTC 2008
>Closed-Date:
>Last-Modified:
>Originator:     Guido Falsi
>Release:        FreeBSD 7.1-PRERELEASE i386
>Organization:
none
>Environment:
System: FreeBSD megatron.madpilot.net 7.1-PRERELEASE FreeBSD 7.1-PRERELEASE #11: Sun Sep 14 13:46:56 CEST 2008 root@megatron.madpilot.net:/usr/obj/usr/src/sys/MEGATRON i386

>Description:

Upgrade to 0.6.27.

added file:
files/patch-common-devices-unixbluetooth.c

This one contains a rewrite of one of the functions to interface
it with bluetooth sdp.

Sent it to original author for inclusion. Since I'm not an experienced
c programmer any check on this code is welcome.

I wrote it with help from the people at the bluetooth@freebsd.org
mailing list, Especially Maksim Yevmenkin and Iain Hibbert, and
taking ideas from FreeBSD's bluetooth stack source code.

>How-To-Repeat:
>Fix:

diff -ruN gnokii.old/Makefile gnokii/Makefile
--- gnokii.old/Makefile	2008-10-06 22:32:36.000000000 +0200
+++ gnokii/Makefile	2008-10-06 22:33:43.000000000 +0200
@@ -6,8 +6,7 @@
 #
 
 PORTNAME=	gnokii
-PORTVERSION=	0.6.26
-PORTREVISION=	3
+PORTVERSION=	0.6.27
 PORTEPOCH=	1
 CATEGORIES=	comms
 MASTER_SITES=	http://www.gnokii.org/download/gnokii/ \
diff -ruN gnokii.old/distinfo gnokii/distinfo
--- gnokii.old/distinfo	2008-10-06 22:32:36.000000000 +0200
+++ gnokii/distinfo	2008-10-06 22:33:43.000000000 +0200
@@ -1,3 +1,3 @@
-MD5 (gnokii-0.6.26.tar.bz2) = 60f817d8ce748fea0ec9a05b3537e08d
-SHA256 (gnokii-0.6.26.tar.bz2) = 35242b5545ced25383ac8c771b602c15b5585063c3637a23c9ef0a31d3e591ea
-SIZE (gnokii-0.6.26.tar.bz2) = 1446615
+MD5 (gnokii-0.6.27.tar.bz2) = fd0ae7996a2e2a2c29e9f3c625df8f3d
+SHA256 (gnokii-0.6.27.tar.bz2) = 69f1d75f755a2918e9577cf28dacea9d6fca9b9d722813341d50d12acb8ee886
+SIZE (gnokii-0.6.27.tar.bz2) = 1491564
diff -ruN gnokii.old/files/patch-common-devices-unixbluetooth.c gnokii/files/patch-common-devices-unixbluetooth.c
--- gnokii.old/files/patch-common-devices-unixbluetooth.c	1970-01-01 01:00:00.000000000 +0100
+++ gnokii/files/patch-common-devices-unixbluetooth.c	2008-11-04 22:31:28.000000000 +0100
@@ -0,0 +1,321 @@
+--- common/devices/unixbluetooth.c.orig	2008-10-05 12:14:31.000000000 +0200
++++ common/devices/unixbluetooth.c	2008-11-04 22:30:35.000000000 +0100
+@@ -54,6 +54,8 @@
+ #include <netgraph/bluetooth/include/ng_hci.h>
+ #include <netgraph/bluetooth/include/ng_l2cap.h>
+ #include <netgraph/bluetooth/include/ng_btsocket.h>
++#include <bluetooth.h>
++#include <sdp.h>
+ 
+ #define BTPROTO_RFCOMM BLUETOOTH_PROTO_RFCOMM
+ #define BDADDR_ANY NG_HCI_BDADDR_ANY
+@@ -86,11 +88,6 @@
+ 
+ #endif	/* HAVE_BT_ATON */
+ 
+-static int str2ba(const char *str, bdaddr_t *ba)
+-{
+-	return !bt_aton(str, ba);
+-}
+-
+ #else	/* Linux / BlueZ support */
+ 
+ #include <bluetooth/bluetooth.h>
+@@ -100,6 +97,272 @@
+ 
+ #endif
+ 
++#ifdef HAVE_BLUETOOTH_NETGRAPH	/* FreeBSD / netgraph */
++
++/*
++** FreeBSD version of the find_service_channel function.
++** Written by Guido Falsi <mad@madpilot.net>.
++** Contains code taken from FreeBSD's sdpcontrol and rfcomm_sppd
++** programs, which are Copyright (c) 2001-2003 Maksim Yevmenkin
++** <m_evmenkin@yahoo.com>.
++*/
++
++static int find_service_channel(bdaddr_t *adapter, bdaddr_t *device, int only_gnapplet, uint16_t svclass_id)
++{
++	uint8_t getchan = 0;
++	uint32_t i, good = 0;
++	char name[64];
++	void *ss = NULL;
++
++	uint32_t attrs[] =
++	{
++		SDP_ATTR_RANGE( SDP_ATTR_PRIMARY_LANGUAGE_BASE_ID + SDP_ATTR_SERVICE_NAME_OFFSET,
++			SDP_ATTR_PRIMARY_LANGUAGE_BASE_ID + SDP_ATTR_SERVICE_NAME_OFFSET),
++		SDP_ATTR_RANGE( SDP_ATTR_PROTOCOL_DESCRIPTOR_LIST,
++			SDP_ATTR_PROTOCOL_DESCRIPTOR_LIST),
++	};
++	#define attrs_len	(sizeof(attrs)/sizeof(attrs[0]))
++
++	/* Buffer for the attributes */
++	#define NRECS   25      /* request this much records from the SDP server */
++	#define BSIZE   256     /* one attribute buffer size */
++	static uint8_t          buffer[NRECS * attrs_len][BSIZE];
++
++	/* SDP attributes */
++	static sdp_attr_t       values[NRECS * attrs_len];
++	#define values_len      (sizeof(values)/sizeof(values[0]))
++
++	/* Initialize attribute values array */
++	for (i = 0; i < values_len; i ++) {
++		values[i].flags = SDP_ATTR_INVALID;
++		values[i].attr = 0;
++		values[i].vlen = BSIZE; 
++		values[i].value = buffer[i];
++	}
++
++	if ((ss = sdp_open(adapter, device)) == NULL)
++		return -1;
++
++	if (sdp_error(ss) != 0)
++	{
++		sdp_close(ss);
++		return -1;
++	}
++
++	if (sdp_search(ss, 1, &svclass_id, attrs_len, attrs, values_len, values) != 0)
++	{
++		sdp_close(ss);
++		return -1;
++	}
++
++	for (i = 0; i < values_len; i++)
++	{
++		if (values[i].flags != SDP_ATTR_OK)
++			break;
++
++		union {
++			uint8_t		uint8;
++			uint16_t	uint16;
++			uint32_t	uint32;
++			uint64_t	uint64;
++			int128_t	int128;
++		}			value;
++		uint8_t *start, *end;
++		uint32_t type, len;
++
++		start = values[i].value;
++		end = values[i].value + values[i].vlen;
++
++		switch (values[i].attr) {
++		case SDP_ATTR_PROTOCOL_DESCRIPTOR_LIST:
++			if(getchan) {
++				SDP_GET8(type, start);
++				switch (type) {
++				case SDP_DATA_SEQ8:
++					SDP_GET8(len, start);
++					break;
++
++				case SDP_DATA_SEQ16:
++					SDP_GET16(len, start);
++					break;
++
++				case SDP_DATA_SEQ32:
++					SDP_GET32(len, start);
++					break;
++
++				default:
++					sdp_close(ss);
++					return -1;
++					break;
++				}
++
++				SDP_GET8(type, start);
++				switch (type) {
++				case SDP_DATA_SEQ8:
++					SDP_GET8(len, start);
++					break;
++
++				case SDP_DATA_SEQ16:
++					SDP_GET16(len, start);
++					break;
++
++				case SDP_DATA_SEQ32:
++					SDP_GET32(len, start);
++					break;
++
++				default:
++					sdp_close(ss);
++					return -1;
++					break;
++				}
++
++				while (start < end) {
++					SDP_GET8(type, start);
++					switch (type) {
++					case SDP_DATA_UUID16:
++						SDP_GET16(value.uint16, start);
++						break;
++
++					case SDP_DATA_UUID32:
++						SDP_GET32(value.uint32, start);
++						break;
++
++					case SDP_DATA_UUID128:
++						SDP_GET_UUID128(&value.int128, start);
++						break;
++
++					default:
++						sdp_close(ss);
++						return -1;
++						break;
++					}
++					if(value.uint16 == 3) {
++						SDP_GET8(type, start);
++						switch (type) {
++						case SDP_DATA_UINT8:
++						case SDP_DATA_INT8:
++							SDP_GET8(value.uint8, start);
++							return value.uint8;
++							break;
++
++						case SDP_DATA_UINT16:
++						case SDP_DATA_INT16:
++							SDP_GET16(value.uint16, start);
++							return value.uint16;
++							break;
++
++						case SDP_DATA_UINT32:
++						case SDP_DATA_INT32:
++							SDP_GET32(value.uint32, start);
++							return value.uint32;
++							break;
++
++						default:
++							sdp_close(ss);
++							return -1;
++							break;
++						}
++					} else {
++						SDP_GET8(type, start);
++						switch (type) {
++						case SDP_DATA_SEQ8:
++						case SDP_DATA_UINT8:
++						case SDP_DATA_INT8:
++						case SDP_DATA_BOOL:
++							SDP_GET8(value.uint8, start);
++							break;
++
++						case SDP_DATA_SEQ16:
++						case SDP_DATA_UINT16:
++						case SDP_DATA_INT16:
++						case SDP_DATA_UUID16:
++							SDP_GET16(value.uint16, start);
++							break;
++
++						case SDP_DATA_SEQ32:
++						case SDP_DATA_UINT32:
++						case SDP_DATA_INT32:
++						case SDP_DATA_UUID32:
++							SDP_GET32(value.uint32, start);
++							break;
++
++						case SDP_DATA_UINT64:
++						case SDP_DATA_INT64:
++							SDP_GET64(value.uint64, start);
++							break;
++
++						case SDP_DATA_UINT128:
++						case SDP_DATA_INT128:
++							SDP_GET128(&value.int128, start);
++							break;
++
++						default:
++							sdp_close(ss);
++							return -1;
++							break;
++						}
++					}
++				}
++			}
++			start += len;
++			break;
++
++		case SDP_ATTR_PRIMARY_LANGUAGE_BASE_ID + SDP_ATTR_SERVICE_NAME_OFFSET:
++			SDP_GET8(type, start);
++			switch (type) {
++				case SDP_DATA_STR8:
++				case SDP_DATA_URL8:
++					SDP_GET8(len, start);
++					snprintf(name, sizeof(name), "%*.*s", len, len, (char *) start);
++					start += len;
++					break;
++
++				case SDP_DATA_STR16:
++				case SDP_DATA_URL16:
++					SDP_GET16(len, start);
++					snprintf(name, sizeof(name), "%*.*s", len, len, (char *) start);
++					start += len;
++					break;
++
++				case SDP_DATA_STR32:
++				case SDP_DATA_URL32:
++					SDP_GET32(len, start);
++					snprintf(name, sizeof(name), "%*.*s", len, len, (char *) start);
++					start += len;
++					break;
++
++				default:
++					sdp_close(ss);
++					return -1;
++			}
++			if (name == NULL)
++				return -1;
++
++			if (strcmp(name, "gnapplet") == 0) {
++				if (only_gnapplet != 0)
++					getchan = 1;
++				break;
++			}
++
++			if (strstr(name, "Nokia PC Suite") != NULL)
++				break;
++
++			if (strstr(name, "Bluetooth Serial Port") != NULL)
++				break;
++
++			if (strstr(name, "m-Router Connectivity") != NULL)
++				break;
++
++			getchan = 1;
++			break;
++		}
++	}
++
++	sdp_close(ss);
++	return -1;
++}
++
++#else
+ /*
+  * Taken from gnome-phone-manager
+  */
+@@ -204,6 +467,8 @@
+ 	return channel;
+ }
+ 
++#endif
++
+ static int get_serial_channel(bdaddr_t *device)
+ {
+ 	bdaddr_t src;
+@@ -211,9 +476,15 @@
+ 
+ 	bacpy(&src, BDADDR_ANY);
+ 
++#ifdef HAVE_BLUETOOTH_NETGRAPH	/* FreeBSD / netgraph */
++	channel = find_service_channel(&src, device, 0, SDP_SERVICE_CLASS_SERIAL_PORT);
++	if (channel < 0)
++		channel = find_service_channel(&src, device, 0, SDP_SERVICE_CLASS_DIALUP_NETWORKING);
++#else
+ 	channel = find_service_channel(&src, device, 0, SERIAL_PORT_SVCLASS_ID);
+ 	if (channel < 0)
+ 		channel = find_service_channel(&src, device, 0, DIALUP_NET_SVCLASS_ID);
++#endif
+ 
+ 	return channel;
+ }
diff -ruN gnokii.old/files/patch-configure gnokii/files/patch-configure
--- gnokii.old/files/patch-configure	2008-10-06 22:32:36.000000000 +0200
+++ gnokii/files/patch-configure	2008-11-01 00:28:38.000000000 +0100
@@ -1,6 +1,6 @@
---- configure.orig     2008-02-15 10:21:49.000000000 +0100
-+++ configure  2008-02-23 11:08:39.000000000 +0100
-@@ -1050,7 +1050,7 @@
+--- configure.orig	2008-10-06 08:57:27.000000000 +0200
++++ configure	2008-11-01 00:28:22.000000000 +0100
+@@ -1057,7 +1057,7 @@
  psdir='${docdir}'
  libdir='${exec_prefix}/lib'
  localedir='${datarootdir}/locale'
@@ -9,7 +9,7 @@
  
  ac_prev=
  ac_dashdash=
-@@ -22653,13 +22653,15 @@
+@@ -24163,13 +24163,15 @@
  # First of all, check if the user has set any of the PTHREAD_LIBS,
  # etcetera environment variables, and if threads linking works using
  # them:
@@ -30,7 +30,7 @@
          cat >conftest.$ac_ext <<_ACEOF
  /* confdefs.h.  */
  _ACEOF
-@@ -23023,7 +23025,7 @@
+@@ -24533,7 +24535,7 @@
  echo $ECHO_N "checking if more special flags are required for pthreads... $ECHO_C" >&6; }
          flag=no
          case "${host_cpu}-${host_os}" in
@@ -39,21 +39,96 @@
                  *solaris* | *-osf* | *-hpux*) flag="-D_REENTRANT";;
          esac
          { echo "$as_me:$LINENO: result: ${flag}" >&5
-@@ -23840,7 +23842,7 @@
+@@ -26561,9 +26563,9 @@
+ fi
  
- if test "$enable_libical" == "yes"; then
+ 
+-if test "$enable_libical" == "yes"; then
++if test "$enable_libical" = "yes"; then
  	OLD_CFLAGS="$CFLAGS"
 -	LIBS="$LIBS $ICAL_LIBS -lpthread -lical"
 +	LIBS="$LIBS $ICAL_LIBS -pthread -lical"
  	CFLAGS="$CFLAGS $ICAL_CFLAGS"
  	{ echo "$as_me:$LINENO: checking whether libical is installed" >&5
  echo $ECHO_N "checking whether libical is installed... $ECHO_C" >&6; }
-@@ -25684,7 +25686,7 @@
+@@ -26650,7 +26652,7 @@
+   enable_libusb=yes
+ fi
+ 
+-if test "$enable_libusb" == "yes"; then
++if test "$enable_libusb" = "yes"; then
+ 	{ echo "$as_me:$LINENO: checking whether libusb is installed" >&5
+ echo $ECHO_N "checking whether libusb is installed... $ECHO_C" >&6; }
+ 	cat >conftest.$ac_ext <<_ACEOF
+@@ -26872,7 +26874,7 @@
+   enable_irda=yes
+ fi
+ 
+-if test "$enable_irda" == "yes"; then
++if test "$enable_irda" = "yes"; then
+ 	{ echo "$as_me:$LINENO: checking for linux/irda.h" >&5
+ echo $ECHO_N "checking for linux/irda.h... $ECHO_C" >&6; }
+ if test "${ac_cv_header_linux_irda_h+set}" = set; then
+@@ -26955,7 +26957,7 @@
+   enable_bluetooth=yes
+ fi
+ 
+-if test "$enable_bluetooth" == "yes"; then
++if test "$enable_bluetooth" = "yes"; then
+ 	{ echo "$as_me:$LINENO: checking for the bluetooth support" >&5
+ echo $ECHO_N "checking for the bluetooth support... $ECHO_C" >&6; }
+ 	{ echo "$as_me:$LINENO: checking for the struct sockaddr_rc in <bluetooth/rfcomm.h>" >&5
+@@ -27025,7 +27027,7 @@
+ 
+ 	fi
+ fi
+-if test "$enable_bluetooth" == "yes"; then
++if test "$enable_bluetooth" = "yes"; then
+ 	{ echo "$as_me:$LINENO: checking for the MacOS X bluetooth support" >&5
+ echo $ECHO_N "checking for the MacOS X bluetooth support... $ECHO_C" >&6; }
+ 
+@@ -27526,7 +27528,7 @@
+ 	fi
+ fi
+ 
+-if test "$enable_bluetooth" == "yes"; then
++if test "$enable_bluetooth" = "yes"; then
+ 	{ echo "$as_me:$LINENO: checking for the FreeBSD/netgraph bluetooth support" >&5
+ echo $ECHO_N "checking for the FreeBSD/netgraph bluetooth support... $ECHO_C" >&6; }
+ 	{ echo "$as_me:$LINENO: checking for the struct sockaddr_rfcomm in <netgraph/.../ng_btsocket.h>" >&5
+@@ -27602,7 +27604,7 @@
+   echo $ECHO_N "(cached) $ECHO_C" >&6
+ else
+   ac_check_lib_save_LIBS=$LIBS
+-LIBS="-lbluetooth  $LIBS"
++LIBS="-lsdp -lbluetooth $LIBS"
+ cat >conftest.$ac_ext <<_ACEOF
+ /* confdefs.h.  */
+ _ACEOF
+@@ -27658,7 +27660,7 @@
+ { echo "$as_me:$LINENO: result: $ac_cv_lib_bluetooth_bt_aton" >&5
+ echo "${ECHO_T}$ac_cv_lib_bluetooth_bt_aton" >&6; }
+ if test $ac_cv_lib_bluetooth_bt_aton = yes; then
+-  BLUETOOTH_LIBS="$LIBS -lbluetooth"
++  BLUETOOTH_LIBS="$LIBS -lsdp -lbluetooth"
+ cat >>confdefs.h <<\_ACEOF
+ #define HAVE_BT_ATON
+ _ACEOF
+@@ -27676,7 +27678,7 @@
+   enable_libpcsclite=yes
+ fi
+ 
+-if test "$enable_libpcsclite" == "yes"; then
++if test "$enable_libpcsclite" = "yes"; then
+ 
+ 
+ if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then
+@@ -28474,7 +28476,7 @@
  echo "${ECHO_T}$ac_cv_lib_Xpm_XpmWriteFileFromXpmImage" >&6; }
  if test $ac_cv_lib_Xpm_XpmWriteFileFromXpmImage = yes; then
     XPM_CFLAGS="$XINCL"
 -                  XPM_LIBS="$XLIBS -lXpm -lX11"
 +                  XPM_LIBS="$XLIBS -lXpm -lX11 -lroken -lcrypt"
-
+ 
  cat >>confdefs.h <<\_ACEOF
  #define XPM 1
diff -ruN gnokii.old/pkg-plist gnokii/pkg-plist
--- gnokii.old/pkg-plist	2008-10-06 22:32:36.000000000 +0200
+++ gnokii/pkg-plist	2008-11-04 22:33:14.000000000 +0100
@@ -20,7 +20,7 @@
 lib/libgnokii.a
 lib/libgnokii.la
 lib/libgnokii.so
-lib/libgnokii.so.12
+lib/libgnokii.so.4
 libdata/pkgconfig/gnokii.pc
 libdata/pkgconfig/xgnokii.pc
 sbin/gnokiid
>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20081104220208.5ABB1130C39>