blob: 86bd9b06c55851a1426ef655880c4b1e2d71bee5 [file] [log] [blame]
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/* SPDX-License-Identifier: LGPL-2.1-or-later */
/*
* libmbim-glib -- GLib/GIO based library to control MBIM devices
*
* Copyright (C) 2013 - 2014 Aleksander Morgado <aleksander@aleksander.es>
*/
#ifndef _LIBMBIM_GLIB_MBIM_MESSAGE_H_
#define _LIBMBIM_GLIB_MBIM_MESSAGE_H_
#if !defined (__LIBMBIM_GLIB_H_INSIDE__) && !defined (LIBMBIM_GLIB_COMPILATION)
#error "Only <libmbim-glib.h> can be included directly."
#endif
#include <glib.h>
#include <glib-object.h>
#include "mbim-uuid.h"
#include "mbim-errors.h"
G_BEGIN_DECLS
/**
* SECTION:mbim-message
* @title: MbimMessage
* @short_description: Generic MBIM message handling routines
*
* #MbimMessage is a generic type representing a MBIM message of any kind
* (request, response, indication).
**/
/**
* MbimMessage:
*
* An opaque type representing a MBIM message.
*
* Since: 1.0
*/
typedef struct _MbimMessage MbimMessage;
GType mbim_message_get_type (void) G_GNUC_CONST;
#define MBIM_TYPE_MESSAGE (mbim_message_get_type ())
/**
* MbimIPv4:
* @addr: 4 bytes specifying the IPv4 address.
*
* An IPv4 address.
*
* Since: 1.0
*/
typedef struct _MbimIPv4 MbimIPv4;
struct _MbimIPv4 {
guint8 addr[4];
};
/**
* MbimIPv6:
* @addr: 16 bytes specifying the IPv6 address.
*
* An IPv6 address.
*
* Since: 1.0
*/
typedef struct _MbimIPv6 MbimIPv6;
struct _MbimIPv6 {
guint8 addr[16];
};
/**
* MbimMessageType:
* @MBIM_MESSAGE_TYPE_INVALID: Invalid MBIM message.
* @MBIM_MESSAGE_TYPE_OPEN: Initialization request.
* @MBIM_MESSAGE_TYPE_CLOSE: Close request.
* @MBIM_MESSAGE_TYPE_COMMAND: Command request.
* @MBIM_MESSAGE_TYPE_HOST_ERROR: Host-reported error in the communication.
* @MBIM_MESSAGE_TYPE_OPEN_DONE: Response to initialization request.
* @MBIM_MESSAGE_TYPE_CLOSE_DONE: Response to close request.
* @MBIM_MESSAGE_TYPE_COMMAND_DONE: Response to command request.
* @MBIM_MESSAGE_TYPE_FUNCTION_ERROR: Function-reported error in the communication.
* @MBIM_MESSAGE_TYPE_INDICATE_STATUS: Unsolicited message from the function.
*
* Type of MBIM messages.
*
* Since: 1.0
*/
typedef enum { /*< since=1.0 >*/
MBIM_MESSAGE_TYPE_INVALID = 0x00000000,
/* From Host to Function */
MBIM_MESSAGE_TYPE_OPEN = 0x00000001,
MBIM_MESSAGE_TYPE_CLOSE = 0x00000002,
MBIM_MESSAGE_TYPE_COMMAND = 0x00000003,
MBIM_MESSAGE_TYPE_HOST_ERROR = 0x00000004,
/* From Function to Host */
MBIM_MESSAGE_TYPE_OPEN_DONE = 0x80000001,
MBIM_MESSAGE_TYPE_CLOSE_DONE = 0x80000002,
MBIM_MESSAGE_TYPE_COMMAND_DONE = 0x80000003,
MBIM_MESSAGE_TYPE_FUNCTION_ERROR = 0x80000004,
MBIM_MESSAGE_TYPE_INDICATE_STATUS = 0x80000007
} MbimMessageType;
/*****************************************************************************/
/* Generic message interface */
/**
* mbim_message_new:
* @data: contents of the message.
* @data_length: length of the message.
*
* Create a #MbimMessage with the given contents.
*
* Returns: (transfer full): a newly created #MbimMessage, which should be freed with mbim_message_unref().
*
* Since: 1.0
*/
MbimMessage *mbim_message_new (const guint8 *data,
guint32 data_length);
/**
* mbim_message_dup:
* @self: a #MbimMessage to duplicate.
*
* Create a #MbimMessage with the same contents as @self.
*
* Returns: (transfer full): a newly created #MbimMessage, which should be freed with mbim_message_unref().
*
* Since: 1.0
*/
MbimMessage *mbim_message_dup (const MbimMessage *self);
/**
* mbim_message_ref:
* @self: a #MbimMessage.
*
* Atomically increments the reference count of @self by one.
*
* Returns: (transfer full): the new reference to @self.
*
* Since: 1.0
*/
MbimMessage *mbim_message_ref (MbimMessage *self);
/**
* mbim_message_unref:
* @self: a #MbimMessage.
*
* Atomically decrements the reference count of @self by one.
* If the reference count drops to 0, @self is completely disposed.
*
* Since: 1.0
*/
void mbim_message_unref (MbimMessage *self);
/**
* mbim_message_get_printable:
* @self: a #MbimMessage.
* @line_prefix: prefix string to use in each new generated line.
* @headers_only: %TRUE if only basic headers should be printed.
*
* Gets a printable string with the contents of the whole MBIM message.
*
* This method will not fail if the parsing of the message contents fails,
* a fallback text with the error will be included in the generated printable
* information instead.
*
* Returns: a newly allocated string, which should be freed with g_free().
*
* Since: 1.0
*/
gchar *mbim_message_get_printable (const MbimMessage *self,
const gchar *line_prefix,
gboolean headers_only);
/**
* mbim_message_get_printable_full:
* @self: a #MbimMessage.
* @mbimex_version_major: major version of the agreed MBIMEx support.
* @mbimex_version_minor: minor version of the agreed MBIMEx support.
* @line_prefix: prefix string to use in each new generated line.
* @headers_only: %TRUE if only basic headers should be printed.
* @error: return location for error or %NULL.
*
* Gets a printable string with the contents of the whole MBIM message.
*
* Unlike mbim_message_get_printable(), this method allows specifying the
* MBIMEx version agreed between host and device, so that the correct
* processing and parsing is done on messages in the newer MBIMEx versions.
*
* If @mbimex_version_major < 2, this method behaves exactly as
* mbim_message_get_printable().
*
* If the specified @mbimex_version_major is unsupported, an error will be
* returned.
*
* This method will not fail if the parsing of the message contents fails,
* a fallback text with the error will be included in the generated printable
* information instead.
*
* Returns: a newly allocated string which should be freed with g_free(), or
* #NULL if @error is set.
*
* Since: 1.28
*/
gchar *mbim_message_get_printable_full (const MbimMessage *self,
guint8 mbimex_version_major,
guint8 mbimex_version_minor,
const gchar *line_prefix,
gboolean headers_only,
GError **error);
/**
* mbim_message_get_raw:
* @self: a #MbimMessage.
* @length: (out): return location for the size of the output buffer.
* @error: return location for error or %NULL.
*
* Gets the whole raw data buffer of the #MbimMessage.
*
* Returns: The raw data buffer, or #NULL if @error is set.
*
* Since: 1.0
*/
const guint8 *mbim_message_get_raw (const MbimMessage *self,
guint32 *length,
GError **error);
/**
* mbim_message_get_message_type:
* @self: a #MbimMessage.
*
* Gets the message type.
*
* Returns: a #MbimMessageType.
*
* Since: 1.0
*/
MbimMessageType mbim_message_get_message_type (const MbimMessage *self);
/**
* mbim_message_get_message_length:
* @self: a #MbimMessage.
*
* Gets the whole message length.
*
* Returns: the length of the message.
*
* Since: 1.0
*/
guint32 mbim_message_get_message_length (const MbimMessage *self);
/**
* mbim_message_get_transaction_id:
* @self: a #MbimMessage.
*
* Gets the transaction ID of the message.
*
* Returns: the transaction ID.
*
* Since: 1.0
*/
guint32 mbim_message_get_transaction_id (const MbimMessage *self);
/**
* mbim_message_set_transaction_id:
* @self: a #MbimMessage.
* @transaction_id: the transaction id.
*
* Sets the transaction ID of the message.
*
* Since: 1.0
*/
void mbim_message_set_transaction_id (MbimMessage *self,
guint32 transaction_id);
G_DEFINE_AUTOPTR_CLEANUP_FUNC (MbimMessage, mbim_message_unref)
/*****************************************************************************/
/* 'Open' message interface */
/**
* mbim_message_open_new:
* @transaction_id: transaction ID.
* @max_control_transfer: maximum control transfer.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_OPEN with the specified
* parameters.
*
* Returns: (transfer full): a newly created #MbimMessage. The returned value
* should be freed with mbim_message_unref().
*
* Since: 1.0
*/
MbimMessage *mbim_message_open_new (guint32 transaction_id,
guint32 max_control_transfer);
/**
* mbim_message_open_get_max_control_transfer:
* @self: a #MbimMessage.
*
* Get the maximum control transfer set to be used in the #MbimMessage of type
* %MBIM_MESSAGE_TYPE_OPEN.
*
* Returns: the maximum control transfer.
*
* Since: 1.0
*/
guint32 mbim_message_open_get_max_control_transfer (const MbimMessage *self);
/*****************************************************************************/
/* 'Open Done' message interface */
/**
* mbim_message_open_done_new:
* @transaction_id: transaction ID.
* @error_status_code: a #MbimStatusError.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_OPEN_DONE with the specified
* parameters.
*
* Returns: (transfer full): a newly created #MbimMessage, which should be freed with mbim_message_unref().
*
* Since: 1.10
*/
MbimMessage *mbim_message_open_done_new (guint32 transaction_id,
MbimStatusError error_status_code);
/**
* mbim_message_open_done_get_status_code:
* @self: a #MbimMessage.
*
* Get status code from the %MBIM_MESSAGE_TYPE_OPEN_DONE message.
*
* Returns: a #MbimStatusError.
*
* Since: 1.0
*/
MbimStatusError mbim_message_open_done_get_status_code (const MbimMessage *self);
/**
* mbim_message_open_done_get_result:
* @self: a #MbimMessage.
* @error: return location for error or %NULL.
*
* Gets the result of the 'Open' operation in the %MBIM_MESSAGE_TYPE_OPEN_DONE message.
*
* Returns: %TRUE if the operation succeeded, %FALSE if @error is set.
*
* Since: 1.0
*/
gboolean mbim_message_open_done_get_result (const MbimMessage *self,
GError **error);
/*****************************************************************************/
/* 'Close' message interface */
/**
* mbim_message_close_new:
* @transaction_id: transaction ID.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_CLOSE with the specified
* parameters.
*
* Returns: (transfer full): a newly created #MbimMessage. The returned value
* should be freed with mbim_message_unref().
*
* Since: 1.0
*/
MbimMessage *mbim_message_close_new (guint32 transaction_id);
/*****************************************************************************/
/* 'Close Done' message interface */
/**
* mbim_message_close_done_new:
* @transaction_id: transaction ID.
* @error_status_code: a #MbimStatusError.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_CLOSE_DONE with the specified
* parameters.
*
* Returns: (transfer full): a newly created #MbimMessage, which should be freed with mbim_message_unref().
*
* Since: 1.10
*/
MbimMessage *mbim_message_close_done_new (guint32 transaction_id,
MbimStatusError error_status_code);
/**
* mbim_message_close_done_get_status_code:
* @self: a #MbimMessage.
*
* Get status code from the %MBIM_MESSAGE_TYPE_CLOSE_DONE message.
*
* Returns: a #MbimStatusError.
*
* Since: 1.0
*/
MbimStatusError mbim_message_close_done_get_status_code (const MbimMessage *self);
/**
* mbim_message_close_done_get_result:
* @self: a #MbimMessage.
* @error: return location for error or %NULL.
*
* Gets the result of the 'Close' operation in the %MBIM_MESSAGE_TYPE_CLOSE_DONE message.
*
* Returns: %TRUE if the operation succeeded, %FALSE if @error is set.
*
* Since: 1.0
*/
gboolean mbim_message_close_done_get_result (const MbimMessage *self,
GError **error);
/*****************************************************************************/
/* 'Error' message interface */
/**
* mbim_message_error_new:
* @transaction_id: transaction ID.
* @error_status_code: a #MbimProtocolError.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_HOST_ERROR with the specified
* parameters.
*
* Returns: (transfer full): a newly created #MbimMessage. The returned value
* should be freed with mbim_message_unref().
*
* Since: 1.0
*/
MbimMessage *mbim_message_error_new (guint32 transaction_id,
MbimProtocolError error_status_code);
/**
* mbim_message_function_error_new:
* @transaction_id: transaction ID.
* @error_status_code: a #MbimProtocolError.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_FUNCTION_ERROR with the specified
* parameters.
*
* Returns: (transfer full): a newly created #MbimMessage. The returned value
* should be freed with mbim_message_unref().
*
* Since: 1.12
*/
MbimMessage *mbim_message_function_error_new (guint32 transaction_id,
MbimProtocolError error_status_code);
/**
* mbim_message_error_get_error_status_code:
* @self: a #MbimMessage.
*
* Get the error code in a %MBIM_MESSAGE_TYPE_HOST_ERROR or
* %MBIM_MESSAGE_TYPE_FUNCTION_ERROR message.
*
* Returns: a #MbimProtocolError.
*
* Since: 1.0
*/
MbimProtocolError mbim_message_error_get_error_status_code (const MbimMessage *self);
/**
* mbim_message_error_get_error:
* @self: a #MbimMessage.
*
* Get the error in a %MBIM_MESSAGE_TYPE_HOST_ERROR or
* %MBIM_MESSAGE_TYPE_FUNCTION_ERROR message.
*
* Returns: a newly allocated #GError, which should be freed with g_error_free().
*
* Since: 1.0
*/
GError *mbim_message_error_get_error (const MbimMessage *self);
/*****************************************************************************/
/* 'Command' message interface */
/**
* MbimMessageCommandType:
* @MBIM_MESSAGE_COMMAND_TYPE_UNKNOWN: Unknown type.
* @MBIM_MESSAGE_COMMAND_TYPE_QUERY: Query command.
* @MBIM_MESSAGE_COMMAND_TYPE_SET: Set command.
*
* Type of command message.
*
* Since: 1.0
*/
typedef enum { /*< since=1.0 >*/
MBIM_MESSAGE_COMMAND_TYPE_UNKNOWN = -1,
MBIM_MESSAGE_COMMAND_TYPE_QUERY = 0,
MBIM_MESSAGE_COMMAND_TYPE_SET = 1
} MbimMessageCommandType;
/**
* mbim_message_command_new:
* @transaction_id: transaction ID.
* @service: a #MbimService.
* @cid: the command ID.
* @command_type: the command type.
*
* Create a new #MbimMessage of type %MBIM_MESSAGE_TYPE_COMMAND with the
* specified parameters and an empty information buffer.
*
* Returns: (transfer full): a newly created #MbimMessage. The returned value
* should be freed with mbim_message_unref().
*
* Since: 1.0
*/
MbimMessage *mbim_message_command_new (guint32 transaction_id,
MbimService service,
guint32 cid,
MbimMessageCommandType command_type);
/**
* mbim_message_command_append:
* @self: a #MbimMessage.
* @buffer: raw buffer to append to the message.
* @buffer_size: length of the data in @buffer.
*
* Appends the contents of @buffer to @self.
*
* Since: 1.0
*/
void mbim_message_command_append (MbimMessage *self,
const guint8 *buffer,
guint32 buffer_size);
/**
* mbim_message_command_get_service:
* @self: a #MbimMessage.
*
* Get the service of a %MBIM_MESSAGE_TYPE_COMMAND message.
*
* Returns: a #MbimService.
*
* Since: 1.0
*/
MbimService mbim_message_command_get_service (const MbimMessage *self);
/**
* mbim_message_command_get_service_id:
* @self: a #MbimMessage.
*
* Get the service UUID of a %MBIM_MESSAGE_TYPE_COMMAND message.
*
* Returns: a #MbimUuid.
*
* Since: 1.0
*/
const MbimUuid *mbim_message_command_get_service_id (const MbimMessage *self);
/**
* mbim_message_command_get_cid:
* @self: a #MbimMessage.
*
* Get the command id of a %MBIM_MESSAGE_TYPE_COMMAND message.
*
* Returns: a CID.
*
* Since: 1.0
*/
guint32 mbim_message_command_get_cid (const MbimMessage *self);
/**
* mbim_message_command_get_command_type:
* @self: a #MbimMessage.
*
* Get the command type of a %MBIM_MESSAGE_TYPE_COMMAND message.
*
* Returns: a #MbimMessageCommandType.
*
* Since: 1.0
*/
MbimMessageCommandType mbim_message_command_get_command_type (const MbimMessage *self);
/**
* mbim_message_command_get_raw_information_buffer:
* @self: a #MbimMessage.
* @out_length: (out): return location for the size of the output buffer.
*
* Gets the information buffer of the %MBIM_MESSAGE_TYPE_COMMAND message.
*
* Returns: (transfer none): The raw data buffer, or #NULL if empty.
*
* Since: 1.0
*/
const guint8 *mbim_message_command_get_raw_information_buffer (const MbimMessage *self,
guint32 *out_length);
/*****************************************************************************/
/* 'Command Done' message interface */
/**
* mbim_message_command_done_get_service:
* @self: a #MbimMessage.
*
* Get the service of a %MBIM_MESSAGE_TYPE_COMMAND_DONE message.
*
* Returns: a #MbimService.
*
* Since: 1.0
*/
MbimService mbim_message_command_done_get_service (const MbimMessage *self);
/**
* mbim_message_command_done_get_service_id:
* @self: a #MbimMessage.
*
* Get the service UUID of a %MBIM_MESSAGE_TYPE_COMMAND_DONE message.
*
* Returns: a #MbimUuid.
*
* Since: 1.0
*/
const MbimUuid *mbim_message_command_done_get_service_id (const MbimMessage *self);
/**
* mbim_message_command_done_get_cid:
* @self: a #MbimMessage.
*
* Get the command id of a %MBIM_MESSAGE_TYPE_COMMAND_DONE message.
*
* Returns: a CID.
*
* Since: 1.0
*/
guint32 mbim_message_command_done_get_cid (const MbimMessage *self);
/**
* mbim_message_command_done_get_status_code:
* @self: a #MbimMessage.
*
* Get status code from the %MBIM_MESSAGE_TYPE_COMMAND_DONE message.
*
* Returns: a #MbimStatusError.
*
* Since: 1.0
*/
MbimStatusError mbim_message_command_done_get_status_code (const MbimMessage *self);
/**
* mbim_message_command_done_get_result:
* @self: a #MbimMessage.
* @error: return location for error or %NULL.
*
* Gets the result of the 'Command' operation in the %MBIM_MESSAGE_TYPE_COMMAND_DONE message.
*
* Returns: %TRUE if the operation succeeded, %FALSE if @error is set.
*
* Since: 1.0
*/
gboolean mbim_message_command_done_get_result (const MbimMessage *self,
GError **error);
/**
* mbim_message_command_done_get_raw_information_buffer:
* @self: a #MbimMessage.
* @out_length: (out): return location for the size of the output buffer.
*
* Gets the information buffer of the %MBIM_MESSAGE_TYPE_COMMAND_DONE message.
*
* Returns: (transfer none): The raw data buffer, or #NULL if empty.
*
* Since: 1.0
*/
const guint8 *mbim_message_command_done_get_raw_information_buffer (const MbimMessage *self,
guint32 *out_length);
/*****************************************************************************/
/* 'Indicate Status' message interface */
/**
* mbim_message_indicate_status_get_service:
* @self: a #MbimMessage.
*
* Get the service of a %MBIM_MESSAGE_TYPE_INDICATE_STATUS message.
*
* Returns: a #MbimService.
*
* Since: 1.0
*/
MbimService mbim_message_indicate_status_get_service (const MbimMessage *self);
/**
* mbim_message_indicate_status_get_service_id:
* @self: a #MbimMessage.
*
* Get the service UUID of a %MBIM_MESSAGE_TYPE_INDICATE_STATUS message.
*
* Returns: a #MbimUuid.
*
* Since: 1.0
*/
const MbimUuid *mbim_message_indicate_status_get_service_id (const MbimMessage *self);
/**
* mbim_message_indicate_status_get_cid:
* @self: a #MbimMessage.
*
* Get the command id of a %MBIM_MESSAGE_TYPE_INDICATE_STATUS message.
*
* Returns: a CID.
*
* Since: 1.0
*/
guint32 mbim_message_indicate_status_get_cid (const MbimMessage *self);
/**
* mbim_message_indicate_status_get_raw_information_buffer:
* @self: a #MbimMessage.
* @out_length: (out): return location for the size of the output buffer.
*
* Gets the information buffer of the %MBIM_MESSAGE_TYPE_INDICATE_STATUS message.
*
* Returns: (transfer none): The raw data buffer, or #NULL if empty.
*
* Since: 1.0
*/
const guint8 *mbim_message_indicate_status_get_raw_information_buffer (const MbimMessage *self,
guint32 *out_length);
/*****************************************************************************/
/* Other helpers */
/**
* mbim_message_response_get_result:
* @self: a #MbimMessage response message.
* @expected: expected #MbimMessageType if there isn't any error in the operation.
* @error: return location for error or %NULL.
*
* Gets the result of the operation from the response message, which
* can be either a %MBIM_MESSAGE_TYPE_FUNCTION_ERROR message or a message of the
* specified @expected type.
*
* Returns: %TRUE if the operation succeeded, %FALSE if @error is set.
*
* Since: 1.12
*/
gboolean mbim_message_response_get_result (const MbimMessage *self,
MbimMessageType expected,
GError **error);
G_END_DECLS
#endif /* _LIBMBIM_GLIB_MBIM_MESSAGE_H_ */