| /* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ |
| /* |
| * libqmi-glib -- GLib/GIO based library to control QMI devices |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the |
| * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301 USA. |
| * |
| * Copyright (C) 2012-2017 Aleksander Morgado <aleksander@aleksander.es> |
| */ |
| |
| #ifndef _LIBQMI_GLIB_QMI_CLIENT_H_ |
| #define _LIBQMI_GLIB_QMI_CLIENT_H_ |
| |
| #if !defined (__LIBQMI_GLIB_H_INSIDE__) && !defined (LIBQMI_GLIB_COMPILATION) |
| #error "Only <libqmi-glib.h> can be included directly." |
| #endif |
| |
| #include <glib-object.h> |
| |
| #include "qmi-enums.h" |
| #include "qmi-message.h" |
| |
| G_BEGIN_DECLS |
| |
| /** |
| * SECTION:qmi-client |
| * @title: QmiClient |
| * @short_description: Generic QMI client handling routines |
| * |
| * #QmiClient is a generic type representing a QMI client for any kind of |
| * #QmiService. |
| * |
| * These objects are created by a #QmiDevice with qmi_device_allocate_client(), |
| * and before completely disposing them qmi_device_release_client() needs to be |
| * called in order to release the unique client ID reserved. |
| */ |
| |
| /** |
| * QMI_CID_NONE: |
| * |
| * A symbol specifying a special CID value that references no CID. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CID_NONE 0x00 |
| |
| /** |
| * QMI_CID_BROADCAST: |
| * |
| * A symbol specifying the broadcast CID. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CID_BROADCAST 0xFF |
| |
| #define QMI_TYPE_CLIENT (qmi_client_get_type ()) |
| #define QMI_CLIENT(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), QMI_TYPE_CLIENT, QmiClient)) |
| #define QMI_CLIENT_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), QMI_TYPE_CLIENT, QmiClientClass)) |
| #define QMI_IS_CLIENT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), QMI_TYPE_CLIENT)) |
| #define QMI_IS_CLIENT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), QMI_TYPE_CLIENT)) |
| #define QMI_CLIENT_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), QMI_TYPE_CLIENT, QmiClientClass)) |
| |
| typedef struct _QmiClient QmiClient; |
| typedef struct _QmiClientClass QmiClientClass; |
| typedef struct _QmiClientPrivate QmiClientPrivate; |
| |
| /** |
| * QMI_CLIENT_DEVICE: |
| * |
| * Symbol defining the #QmiClient:client-device property. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CLIENT_DEVICE "client-device" |
| |
| /** |
| * QMI_CLIENT_SERVICE: |
| * |
| * Symbol defining the #QmiClient:client-service property. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CLIENT_SERVICE "client-service" |
| |
| /** |
| * QMI_CLIENT_CID: |
| * |
| * Symbol defining the #QmiClient:client-cid property. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CLIENT_CID "client-cid" |
| |
| /** |
| * QMI_CLIENT_VERSION_MAJOR: |
| * |
| * Symbol defining the #QmiClient:client-version-major property. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CLIENT_VERSION_MAJOR "client-version-major" |
| |
| /** |
| * QMI_CLIENT_VERSION_MINOR: |
| * |
| * Symbol defining the #QmiClient:client-version-minor property. |
| * |
| * Since: 1.0 |
| */ |
| #define QMI_CLIENT_VERSION_MINOR "client-version-minor" |
| |
| /** |
| * QMI_CLIENT_VALID: |
| * |
| * Symbol defining the #QmiClient:client-valid property. |
| * |
| * Since: 1.20 |
| */ |
| #define QMI_CLIENT_VALID "client-valid" |
| |
| /** |
| * QmiClient: |
| * |
| * The #QmiClient structure contains private data and should only be accessed |
| * using the provided API. |
| * |
| * Since: 1.0 |
| */ |
| struct _QmiClient { |
| /*< private >*/ |
| GObject parent; |
| QmiClientPrivate *priv; |
| }; |
| |
| struct _QmiClientClass { |
| /*< private >*/ |
| GObjectClass parent; |
| |
| /* Virtual method to get indications processed */ |
| void (* process_indication) (QmiClient *self, |
| QmiMessage *message); |
| }; |
| |
| GType qmi_client_get_type (void); |
| G_DEFINE_AUTOPTR_CLEANUP_FUNC (QmiClient, g_object_unref) |
| |
| /** |
| * qmi_client_get_device: |
| * @self: a #QmiClient |
| * |
| * Get the #QmiDevice associated with this #QmiClient. |
| * |
| * Returns: (transfer full): a #GObject that must be freed with g_object_unref(). |
| * |
| * Since: 1.0 |
| */ |
| GObject *qmi_client_get_device (QmiClient *self); |
| |
| /** |
| * qmi_client_peek_device: |
| * @self: a #QmiClient. |
| * |
| * Get the #QmiDevice associated with this #QmiClient, without increasing the reference count |
| * on the returned object. |
| * |
| * Returns: (transfer none): a #GObject. Do not free the returned object, it is owned by @self. |
| * |
| * Since: 1.0 |
| */ |
| GObject *qmi_client_peek_device (QmiClient *self); |
| |
| /** |
| * qmi_client_get_service: |
| * @self: A #QmiClient |
| * |
| * Get the service being used by this #QmiClient. |
| * |
| * Returns: a #QmiService. |
| * |
| * Since: 1.0 |
| */ |
| QmiService qmi_client_get_service (QmiClient *self); |
| |
| /** |
| * qmi_client_get_cid: |
| * @self: A #QmiClient |
| * |
| * Get the client ID of this #QmiClient. |
| * |
| * Returns: the client ID. |
| * |
| * Since: 1.0 |
| */ |
| guint8 qmi_client_get_cid (QmiClient *self); |
| |
| /** |
| * qmi_client_is_valid: |
| * @self: a #QmiClient. |
| * |
| * Checks whether #QmiClient is a valid and usable client. |
| * |
| * The client is marked as invalid as soon as the client id is released or when |
| * the associated #QmiDevice is closed. |
| * |
| * This method may be used if the caller needs to ensure validity before a |
| * command is attempted, e.g. if the lifecycle of the object is managed in some |
| * other place and the caller just has a reference to the #QmiClient. |
| * |
| * Returns: %TRUE if the client is valid, %FALSE otherwise. |
| * |
| * Since: 1.20 |
| */ |
| gboolean qmi_client_is_valid (QmiClient *self); |
| |
| /** |
| * qmi_client_get_version: |
| * @self: A #QmiClient |
| * @major: placeholder for the output major version. |
| * @minor: placeholder for the output minor version. |
| * |
| * Get the version of the service handled by this #QmiClient. |
| * |
| * Returns: %TRUE if the version was properly reported, %FALSE otherwise. |
| * |
| * Since: 1.0 |
| */ |
| gboolean qmi_client_get_version (QmiClient *self, |
| guint *major, |
| guint *minor); |
| |
| /** |
| * qmi_client_check_version: |
| * @self: A #QmiClient |
| * @major: a major version. |
| * @minor: a minor version. |
| * |
| * Checks if the version of the service handled by this #QmiClient is greater |
| * or equal than the given version. |
| * |
| * Returns: %TRUE if the version of the service is greater or equal than the one given, %FALSE otherwise. |
| * |
| * Since: 1.0 |
| */ |
| gboolean qmi_client_check_version (QmiClient *self, |
| guint major, |
| guint minor); |
| |
| /** |
| * qmi_client_get_next_transaction_id: |
| * @self: A #QmiClient |
| * |
| * Acquire the next transaction ID of this #QmiClient. |
| * The internal transaction ID gets incremented. |
| * |
| * Returns: the next transaction ID. |
| * |
| * Since: 1.0 |
| */ |
| guint16 qmi_client_get_next_transaction_id (QmiClient *self); |
| |
| /* not part of the public API */ |
| |
| #if defined (LIBQMI_GLIB_COMPILATION) |
| G_GNUC_INTERNAL |
| void __qmi_client_process_indication (QmiClient *self, |
| QmiMessage *message); |
| #endif |
| |
| G_END_DECLS |
| |
| #endif /* _LIBQMI_GLIB_QMI_CLIENT_H_ */ |