[PATCH v2 20/23] libusbg: Change usbg_get_function_attrs() to return error code.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



usbg_get_function_attrs() may fail due to many reasons
so it should notify the user about exact reason of failure
instead of returning only NULL pointer.

Add also USBG_ERROR_NOT_SUPPORTED to usbg_set_function_attrs().

Signed-off-by: Krzysztof Opasiak <k.opasiak@xxxxxxxxxxx>
---
 include/usbg/usbg.h |    5 ++--
 src/usbg.c          |   77 +++++++++++++++++++++++++++++++++++----------------
 2 files changed, 56 insertions(+), 26 deletions(-)

diff --git a/include/usbg/usbg.h b/include/usbg/usbg.h
index 1bb652e..ae53d22 100644
--- a/include/usbg/usbg.h
+++ b/include/usbg/usbg.h
@@ -189,6 +189,7 @@ typedef enum  {
 	USBG_ERROR_EXIST = -6,
 	USBG_ERROR_NO_DEV = -7,
 	USBG_ERROR_BUSY = -8,
+	USBG_ERROR_NOT_SUPPORTED = -9,
 	USBG_ERROR_OTHER_ERROR = -99
 } usbg_error;
 
@@ -641,9 +642,9 @@ extern usbg_function_type usbg_get_function_type(usbg_function *f);
  * @brief Get attributes of given function
  * @param f Pointer to function
  * @param f_attrs Union to be filled
- * @return Pointer to filled structure or NULL if error occurred.
+ * @return 0 on success usbg_error if error occurred.
  */
-extern usbg_function_attrs *usbg_get_function_attrs(usbg_function *f,
+extern int usbg_get_function_attrs(usbg_function *f,
 		usbg_function_attrs *f_attrs);
 
 /**
diff --git a/src/usbg.c b/src/usbg.c
index f97ad1d..3589dd0 100644
--- a/src/usbg.c
+++ b/src/usbg.c
@@ -365,43 +365,76 @@ static void usbg_free_state(usbg_state *s)
 	free(s);
 }
 
-
-static void usbg_parse_function_attrs(usbg_function *f,
+static int usbg_parse_function_net_attrs(usbg_function *f,
 		usbg_function_attrs *f_attrs)
 {
 	struct ether_addr *addr;
 	char str_addr[40];
+	int ret;
+
+	ret = usbg_read_string(f->path, f->name, "dev_addr", str_addr);
+	if (ret != USBG_SUCCESS)
+		goto out;
+
+	addr = ether_aton(str_addr);
+	if (addr) {
+		f_attrs->net.dev_addr = *addr;
+	} else {
+		ret = USBG_ERROR_IO;
+		goto out;
+	}
+
+	ret = usbg_read_string(f->path, f->name, "host_addr", str_addr);
+	if (ret != USBG_SUCCESS)
+		goto out;
+
+	addr = ether_aton(str_addr);
+	if (addr) {
+		f_attrs->net.host_addr = *addr;
+	} else {
+		ret = USBG_ERROR_IO;
+		goto out;
+	}
+
+	ret = usbg_read_string(f->path, f->name, "ifname", f_attrs->net.ifname);
+	if (ret != USBG_SUCCESS)
+		goto out;
+
+	ret = usbg_read_dec(f->path, f->name, "qmult", &(f_attrs->net.qmult));
+
+out:
+	return ret;
+}
+
+static int usbg_parse_function_attrs(usbg_function *f,
+		usbg_function_attrs *f_attrs)
+{
+	int ret;
 
 	switch (f->type) {
 	case F_SERIAL:
 	case F_ACM:
 	case F_OBEX:
-		usbg_read_dec(f->path, f->name, "port_num", &(f_attrs->serial.port_num));
+		ret = usbg_read_dec(f->path, f->name, "port_num",
+				&(f_attrs->serial.port_num));
 		break;
 	case F_ECM:
 	case F_SUBSET:
 	case F_NCM:
 	case F_EEM:
 	case F_RNDIS:
-		usbg_read_string(f->path, f->name, "dev_addr", str_addr);
-		addr = ether_aton(str_addr);
-		if (addr)
-			f_attrs->net.dev_addr = *addr;
-
-		usbg_read_string(f->path, f->name, "host_addr", str_addr);
-		addr = ether_aton(str_addr);
-		if(addr)
-			f_attrs->net.host_addr = *addr;
-
-		usbg_read_string(f->path, f->name, "ifname", f_attrs->net.ifname);
-		usbg_read_dec(f->path, f->name, "qmult", &(f_attrs->net.qmult));
+		ret = usbg_parse_function_net_attrs(f, f_attrs);
 		break;
 	case F_PHONET:
-		usbg_read_string(f->path, f->name, "ifname", f_attrs->phonet.ifname);
+		ret = usbg_read_string(f->path, f->name, "ifname",
+				f_attrs->phonet.ifname);
 		break;
 	default:
 		ERROR("Unsupported function type\n");
+		ret = USBG_ERROR_NOT_SUPPORTED;
 	}
+
+	return ret;
 }
 
 static int usbg_parse_functions(char *path, usbg_gadget *g)
@@ -1516,15 +1549,10 @@ usbg_function_type usbg_get_function_type(usbg_function *f)
 	return f->type;
 }
 
-usbg_function_attrs *usbg_get_function_attrs(usbg_function *f,
-		usbg_function_attrs *f_attrs)
+int usbg_get_function_attrs(usbg_function *f, usbg_function_attrs *f_attrs)
 {
-	if (f && f_attrs)
-		usbg_parse_function_attrs(f, f_attrs);
-	else
-		f_attrs = NULL;
-
-	return f_attrs;
+	return f && f_attrs ? usbg_parse_function_attrs(f, f_attrs)
+			: USBG_ERROR_INVALID_PARAM;
 }
 
 int usbg_set_function_net_attrs(usbg_function *f, usbg_f_net_attrs *attrs)
@@ -1577,6 +1605,7 @@ int  usbg_set_function_attrs(usbg_function *f, usbg_function_attrs *f_attrs)
 		break;
 	default:
 		ERROR("Unsupported function type\n");
+		ret = USBG_ERROR_NOT_SUPPORTED;
 	}
 
 	return ret;
-- 
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux