572 lines
15 KiB
C
572 lines
15 KiB
C
#ifndef UPNP_TV_DEVICE_H
|
|
#define UPNP_TV_DEVICE_H
|
|
|
|
/**************************************************************************
|
|
*
|
|
* Copyright (c) 2000-2003 Intel Corporation
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
*
|
|
* - Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
* - Neither name of Intel Corporation nor the names of its contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL INTEL OR
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
|
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
**************************************************************************/
|
|
|
|
/*!
|
|
* \addtogroup UpnpSamples
|
|
*
|
|
* @{
|
|
*
|
|
* \name Device Sample API
|
|
*
|
|
* @{
|
|
*
|
|
* \file
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <signal.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include "sample_util.h"
|
|
|
|
#include "ithread.h"
|
|
#include "upnp.h"
|
|
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
/*! Color constants */
|
|
#define MAX_COLOR 10
|
|
#define MIN_COLOR 1
|
|
|
|
/*! Brightness constants */
|
|
#define MAX_BRIGHTNESS 10
|
|
#define MIN_BRIGHTNESS 1
|
|
|
|
/*! Power constants */
|
|
#define POWER_ON 1
|
|
#define POWER_OFF 0
|
|
|
|
/*! Tint constants */
|
|
#define MAX_TINT 10
|
|
#define MIN_TINT 1
|
|
|
|
/*! Volume constants */
|
|
#define MAX_VOLUME 10
|
|
#define MIN_VOLUME 1
|
|
|
|
/*! Contrast constants */
|
|
#define MAX_CONTRAST 10
|
|
#define MIN_CONTRAST 1
|
|
|
|
/*! Channel constants */
|
|
#define MAX_CHANNEL 100
|
|
#define MIN_CHANNEL 1
|
|
|
|
/*! Number of services. */
|
|
#define TV_SERVICE_SERVCOUNT 2
|
|
|
|
/*! Index of control service */
|
|
#define TV_SERVICE_CONTROL 0
|
|
|
|
/*! Index of picture service */
|
|
#define TV_SERVICE_PICTURE 1
|
|
|
|
/*! Number of control variables */
|
|
#define TV_CONTROL_VARCOUNT 3
|
|
|
|
/*! Index of power variable */
|
|
#define TV_CONTROL_POWER 0
|
|
|
|
/*! Index of channel variable */
|
|
#define TV_CONTROL_CHANNEL 1
|
|
|
|
/*! Index of volume variable */
|
|
#define TV_CONTROL_VOLUME 2
|
|
|
|
/*! Number of picture variables */
|
|
#define TV_PICTURE_VARCOUNT 4
|
|
|
|
/*! Index of color variable */
|
|
#define TV_PICTURE_COLOR 0
|
|
|
|
/*! Index of tint variable */
|
|
#define TV_PICTURE_TINT 1
|
|
|
|
/*! Index of contrast variable */
|
|
#define TV_PICTURE_CONTRAST 2
|
|
|
|
/*! Index of brightness variable */
|
|
#define TV_PICTURE_BRIGHTNESS 3
|
|
|
|
/*! Max value length */
|
|
#define TV_MAX_VAL_LEN 5
|
|
|
|
/*! Max actions */
|
|
#define TV_MAXACTIONS 12
|
|
|
|
/*! This should be the maximum VARCOUNT from above */
|
|
#define TV_MAXVARS TV_PICTURE_VARCOUNT
|
|
|
|
/*!
|
|
* \brief Prototype for all actions. For each action that a service
|
|
* implements, there is a corresponding function with this prototype.
|
|
*
|
|
* Pointers to these functions, along with action names, are stored
|
|
* in the service table. When an action request comes in the action
|
|
* name is matched, and the appropriate function is called.
|
|
* Each function returns UPNP_E_SUCCESS, on success, and a nonzero
|
|
* error code on failure.
|
|
*/
|
|
typedef int (*upnp_action)(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *request,
|
|
/*! [out] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] Error string in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*! Structure for storing Tv Service identifiers and state table. */
|
|
struct TvService {
|
|
/*! Universally Unique Device Name. */
|
|
char UDN[NAME_SIZE];
|
|
/*! . */
|
|
char ServiceId[NAME_SIZE];
|
|
/*! . */
|
|
char ServiceType[NAME_SIZE];
|
|
/*! . */
|
|
const char *VariableName[TV_MAXVARS];
|
|
/*! . */
|
|
char *VariableStrVal[TV_MAXVARS];
|
|
/*! . */
|
|
const char *ActionNames[TV_MAXACTIONS];
|
|
/*! . */
|
|
upnp_action actions[TV_MAXACTIONS];
|
|
/*! . */
|
|
int VariableCount;
|
|
};
|
|
|
|
/*! Array of service structures */
|
|
extern struct TvService tv_service_table[];
|
|
|
|
/*! Device handle returned from sdk */
|
|
extern UpnpDevice_Handle device_handle;
|
|
|
|
/*! Mutex for protecting the global state table data
|
|
* in a multi-threaded, asynchronous environment.
|
|
* All functions should lock this mutex before reading
|
|
* or writing the state table data. */
|
|
extern ithread_mutex_t TVDevMutex;
|
|
|
|
/*!
|
|
* \brief Initializes the action table for the specified service.
|
|
*
|
|
* Note that knowledge of the service description is assumed.
|
|
* Action names are hardcoded.
|
|
*/
|
|
int SetActionTable(
|
|
/*! [in] one of TV_SERVICE_CONTROL or, TV_SERVICE_PICTURE. */
|
|
int serviceType,
|
|
/*! [in,out] service containing action table to set. */
|
|
struct TvService *out);
|
|
|
|
/*!
|
|
* \brief Initialize the device state table for this TvDevice, pulling
|
|
* identifier info from the description Document.
|
|
*
|
|
* Note that knowledge of the service description is assumed.
|
|
* State table variables and default values are currently hardcoded in
|
|
* this file rather than being read from service description documents.
|
|
*/
|
|
int TvDeviceStateTableInit(
|
|
/*! [in] The description document URL. */
|
|
char *DescDocURL);
|
|
|
|
/*!
|
|
* \brief Called during a subscription request callback.
|
|
*
|
|
* If the subscription request is for this device and either its
|
|
* control service or picture service, then accept it.
|
|
*/
|
|
int TvDeviceHandleSubscriptionRequest(
|
|
/*! [in] The subscription request event structure. */
|
|
struct Upnp_Subscription_Request *sr_event);
|
|
|
|
/*!
|
|
* \brief Called during a get variable request callback.
|
|
*
|
|
* If the request is for this device and either its control service or
|
|
* picture service, then respond with the variable value.
|
|
*/
|
|
int TvDeviceHandleGetVarRequest(
|
|
/*! [in,out] The control get variable request event structure. */
|
|
struct Upnp_State_Var_Request *cgv_event);
|
|
|
|
/*!
|
|
* \brief Called during an action request callback.
|
|
*
|
|
* If the request is for this device and either its control service
|
|
* or picture service, then perform the action and respond.
|
|
*/
|
|
int TvDeviceHandleActionRequest(
|
|
/*! [in,out] The control action request event structure. */
|
|
struct Upnp_Action_Request *ca_event);
|
|
|
|
/*!
|
|
* \brief The callback handler registered with the SDK while registering
|
|
* root device.
|
|
*
|
|
* Dispatches the request to the appropriate procedure
|
|
* based on the value of EventType. The four requests handled by the
|
|
* device are:
|
|
* \li 1) Event Subscription requests.
|
|
* \li 2) Get Variable requests.
|
|
* \li 3) Action requests.
|
|
*/
|
|
int TvDeviceCallbackEventHandler(
|
|
/*! [in] The type of callback event. */
|
|
Upnp_EventType,
|
|
/*! [in] Data structure containing event data. */
|
|
void *Event,
|
|
/*! [in] Optional data specified during callback registration. */
|
|
void *Cookie);
|
|
|
|
/*!
|
|
* \brief Update the TvDevice service state table, and notify all subscribed
|
|
* control points of the updated state.
|
|
*
|
|
* Note that since this function blocks on the mutex TVDevMutex,
|
|
* to avoid a hang this function should not be called within any other
|
|
* function that currently has this mutex locked.
|
|
*/
|
|
int TvDeviceSetServiceTableVar(
|
|
/*! [in] The service number (TV_SERVICE_CONTROL or TV_SERVICE_PICTURE). */
|
|
unsigned int service,
|
|
/*! [in] The variable number (TV_CONTROL_POWER, TV_CONTROL_CHANNEL,
|
|
* TV_CONTROL_VOLUME, TV_PICTURE_COLOR, TV_PICTURE_TINT,
|
|
* TV_PICTURE_CONTRAST, or TV_PICTURE_BRIGHTNESS). */
|
|
int variable,
|
|
/*! [in] The string representation of the new value. */
|
|
char *value);
|
|
|
|
/* Control Service Actions */
|
|
|
|
/*!
|
|
* \brief Turn the power on.
|
|
*/
|
|
int TvDevicePowerOn(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Turn the power off.
|
|
*/
|
|
int TvDevicePowerOff(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Change the channel, update the TvDevice control service
|
|
* state table, and notify all subscribed control points of the
|
|
* updated state.
|
|
*/
|
|
int TvDeviceSetChannel(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Increase the channel.
|
|
*/
|
|
int TvDeviceIncreaseChannel(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Decrease the channel.
|
|
*/
|
|
int TvDeviceDecreaseChannel(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Change the volume, update the TvDevice control service
|
|
* state table, and notify all subscribed control points of the
|
|
* updated state.
|
|
*/
|
|
int TvDeviceSetVolume(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Increase the volume.
|
|
*/
|
|
int TvDeviceIncreaseVolume(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Decrease the volume.
|
|
*/
|
|
int TvDeviceDecreaseVolume(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*Picture Service Actions */
|
|
|
|
/*!
|
|
* \brief Change the color, update the TvDevice picture service
|
|
* state table, and notify all subscribed control points of the
|
|
* updated state.
|
|
*/
|
|
int TvDeviceSetColor(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Increase the color.
|
|
*/
|
|
int TvDeviceIncreaseColor(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Decrease the color.
|
|
*/
|
|
int TvDeviceDecreaseColor(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Change the tint, update the TvDevice picture service
|
|
* state table, and notify all subscribed control points of the
|
|
* updated state.
|
|
*/
|
|
int TvDeviceSetTint(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Increase tint.
|
|
*/
|
|
int TvDeviceIncreaseTint(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Decrease tint.
|
|
*/
|
|
int TvDeviceDecreaseTint(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Change the contrast, update the TvDevice picture service
|
|
* state table, and notify all subscribed control points of the
|
|
* updated state.
|
|
*/
|
|
int TvDeviceSetContrast(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Increase the contrast.
|
|
*/
|
|
int TvDeviceIncreaseContrast(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Decrease the contrast.
|
|
*/
|
|
int TvDeviceDecreaseContrast(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Change the brightness, update the TvDevice picture service
|
|
* state table, and notify all subscribed control points of the
|
|
* updated state.
|
|
*/
|
|
int TvDeviceSetBrightness(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Increase brightnesss.
|
|
*/
|
|
int TvDeviceIncreaseBrightness(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Decrease brightnesss.
|
|
*/
|
|
int TvDeviceDecreaseBrightness(
|
|
/*! [in] Document of action request. */
|
|
IXML_Document *in,
|
|
/*! [in] Action result. */
|
|
IXML_Document **out,
|
|
/*! [out] ErrorString in case action was unsuccessful. */
|
|
const char **errorString);
|
|
|
|
/*!
|
|
* \brief Initializes the UPnP Sdk, registers the device, and sends out
|
|
* advertisements.
|
|
*/
|
|
int TvDeviceStart(
|
|
/*! [in] ip address to initialize the sdk (may be NULL)
|
|
* if null, then the first non null loopback address is used. */
|
|
char *ip_address,
|
|
/*! [in] port number to initialize the sdk (may be 0)
|
|
* if zero, then a random number is used. */
|
|
unsigned short port,
|
|
/*! [in] name of description document.
|
|
* may be NULL. Default is tvdevicedesc.xml. */
|
|
const char *desc_doc_name,
|
|
/*! [in] path of web directory.
|
|
* may be NULL. Default is ./web (for Linux) or ../tvdevice/web. */
|
|
const char *web_dir_path,
|
|
/*! [in] print function to use. */
|
|
print_string pfun,
|
|
/*! [in] Non-zero if called from the combo application. */
|
|
int combo);
|
|
|
|
/*!
|
|
* \brief Stops the device. Uninitializes the sdk.
|
|
*/
|
|
int TvDeviceStop(void);
|
|
|
|
/*!
|
|
* \brief Function that receives commands from the user at the command prompt
|
|
* during the lifetime of the device, and calls the appropriate
|
|
* functions for those commands. Only one command, exit, is currently
|
|
* defined.
|
|
*/
|
|
void *TvDeviceCommandLoop(void *args);
|
|
|
|
/*!
|
|
* \brief Main entry point for tv device application.
|
|
*
|
|
* Initializes and registers with the sdk.
|
|
* Initializes the state stables of the service.
|
|
* Starts the command loop.
|
|
*
|
|
* Accepts the following optional arguments:
|
|
* \li \c -ip ipaddress
|
|
* \li \c -port port
|
|
* \li \c -desc desc_doc_name
|
|
* \li \c -webdir web_dir_path
|
|
* \li \c -help
|
|
*/
|
|
int device_main(int argc, char *argv[]);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
/*! @} Control Point Sample API */
|
|
|
|
/*! @} UpnpSamples */
|
|
|
|
#endif /* UPNP_TV_DEVICE_H */
|