diff --git a/src/device.c b/src/device.c
index f781298..09a154d 100644
--- a/src/device.c
+++ b/src/device.c
DBUS_TYPE_UINT32, &value);
}
+int device_get_appearance(struct btd_device *device, uint16_t *value)
+{
+ bdaddr_t src;
+ uint16_t app;
+ int err;
+
+ adapter_get_address(device_get_adapter(device), &src);
+
+ err = read_remote_appearance(&src, &device->bdaddr,
+ device->bdaddr_type, &app);
+ if (err < 0)
+ return err;
+
+ if (value)
+ *value = app;
+
+ return 0;
+}
+
static gboolean notify_attios(gpointer user_data)
{
struct btd_device *device = user_data;
diff --git a/src/device.h b/src/device.h
index 26e17f7..eb4b41e 100644
--- a/src/device.h
+++ b/src/device.h
GDestroyNotify destroy);
void device_remove_disconnect_watch(struct btd_device *device, guint id);
void device_set_class(struct btd_device *device, uint32_t value);
+int device_get_appearance(struct btd_device *device, uint16_t *value);
#define BTD_UUIDS(args...) ((const char *[]) { args, NULL } )