Mercurial > pt1.oyama
changeset 133:0db6ccf0fe31
modify DLNA display name & UUID
author | Naoya OYAMA <[email protected]> |
---|---|
date | Thu, 14 Oct 2010 00:07:05 +0900 |
parents | 7b663556757f |
children | c4e0a5777363 |
files | src/http.c src/pt1_dev.h src/recpt1.c src/recpt1.h src/ushare.c |
diffstat | 5 files changed, 29 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/src/http.c Wed Oct 13 01:39:24 2010 +0900 +++ b/src/http.c Thu Oct 14 00:07:05 2010 +0900 @@ -29,7 +29,6 @@ #include <stdlib.h> #include <unistd.h> #include <errno.h> -#include <stdint.h> #include <upnp/upnp.h> #include <upnp/upnptools.h>
--- a/src/pt1_dev.h Wed Oct 13 01:39:24 2010 +0900 +++ b/src/pt1_dev.h Thu Oct 14 00:07:05 2010 +0900 @@ -2,6 +2,8 @@ #ifndef _PT1_DEV_H_ #define _PT1_DEV_H_ +#define DEVICE_NAME_BASE "/dev/pt1video" + char *bsdev[NUM_BSDEV] = { "/dev/pt1video1", "/dev/pt1video0",
--- a/src/recpt1.c Wed Oct 13 01:39:24 2010 +0900 +++ b/src/recpt1.c Thu Oct 14 00:07:05 2010 +0900 @@ -54,7 +54,7 @@ /* prototypes */ int tune(char *channel, thread_data *tdata, char *device); int close_tuner(thread_data *tdata); - +static int get_device_id_by_name ( const char *name ); /* ipc message receive */ void * @@ -972,6 +972,7 @@ /* case 1: specified tuner device */ if(device) { tdata->tfd = open(device, O_RDONLY); + tdata->device_id = get_device_id_by_name(device); if(tdata->tfd < 0) { fprintf(stderr, "Cannot open tuner device: %s\n", device); return 1; @@ -1022,6 +1023,7 @@ continue; } + tdata->device_id = get_device_id_by_name(tuner[lp]); break; /* found suitable tuner */ } } @@ -1506,3 +1508,15 @@ return 0; } +static int +get_device_id_by_name +( const char *name ) +{ + int i = -1; + if ( name != NULL ) { + if( ! strncmp(name, DEVICE_NAME_BASE, strlen(DEVICE_NAME_BASE) ) ) { + i = atoi(name+strlen(DEVICE_NAME_BASE)); + } + } + return i; +}
--- a/src/recpt1.h Wed Oct 13 01:39:24 2010 +0900 +++ b/src/recpt1.h Thu Oct 14 00:07:05 2010 +0900 @@ -88,6 +88,7 @@ int lnb; /* LNB voltage */ int tfd; /* tuner fd */ int wfd; /* output file fd */ + int device_id; /* /dev/pt1video[N] */ ISDB_T_FREQ_CONV_TABLE *table; sock_data *sock_data; pthread_t signal_thread;
--- a/src/ushare.c Wed Oct 13 01:39:24 2010 +0900 +++ b/src/ushare.c Thu Oct 14 00:07:05 2010 +0900 @@ -82,15 +82,21 @@ static struct ushare_t * ushare_new (void) { + extern thread_data *gp_tdata; + thread_data *tdata = gp_tdata; struct ushare_t *ut = (struct ushare_t *) malloc (sizeof (struct ushare_t)); + char model_name[32]; + model_name[0] = '\0'; if (!ut) return NULL; + snprintf(model_name, sizeof(model_name), "%s:dev%d", PACKAGE_NAME, tdata->device_id); + model_name[sizeof(model_name)-1] = '\0'; // ut->name = strdup (DEFAULT_USHARE_NAME); - ut->name = strdup (PACKAGE_NAME); + ut->name = strdup (model_name); ut->interface = strdup (DEFAULT_USHARE_IFACE); // ut->model_name = strdup (DEFAULT_USHARE_NAME); - ut->model_name = strdup (PACKAGE_NAME); + ut->model_name = strdup (model_name); ut->contentlist = NULL; ut->rb = rbinit (rb_compare, NULL); ut->root_entry = NULL; @@ -504,10 +510,11 @@ static char * create_udn (char *interface) { + extern thread_data *gp_tdata; + thread_data *tdata = gp_tdata; int sock = -1; char *buf; unsigned char *ptr; - pid_t PID = (getpid() & 0xFFFF); #if (defined(BSD) || defined(__FreeBSD__) || defined(__APPLE__)) int mib[6]; @@ -574,7 +581,7 @@ ptr = (unsigned char *) ifr.ifr_hwaddr.sa_data; #endif /* (defined(BSD) || defined(__FreeBSD__)) */ - snprintf (buf, 64, "%s-%04x-%02x%02x%02x%02x%02x%02x", DEFAULT_UUID, PID, + snprintf (buf, 64, "%s-%04x-%02x%02x%02x%02x%02x%02x", DEFAULT_UUID, tdata->device_id, (ptr[0] & 0377), (ptr[1] & 0377), (ptr[2] & 0377), (ptr[3] & 0377), (ptr[4] & 0377), (ptr[5] & 0377));