From: Bryan O'Donoghue Date: Mon, 13 Jul 2015 19:20:48 +0000 (+0100) Subject: greybus: loopback: make loopback type input equivalent to protocol type X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=a598f4384d9e95532781adc316793983ed27139d;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git greybus: loopback: make loopback type input equivalent to protocol type Sepcifying loopback operation type with a type value that is internal to the loopback driver is non-intunitive and requires reading code to understand. Remove confusing duplicate definitions and update code to accept the greybus-specification function identity defintiions as the appropriate type values for initiating loopback operations. See greybus-spec section 10.16.1 'Greybus Loopback Message Types' for a full list of valid messages to set this type field to. Signed-off-by: Bryan O'Donoghue Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/greybus/loopback.c b/drivers/staging/greybus/loopback.c index 6cd4acf93bf6..bdbebd6dbede 100644 --- a/drivers/staging/greybus/loopback.c +++ b/drivers/staging/greybus/loopback.c @@ -45,12 +45,6 @@ struct gb_loopback { u32 error; }; -/* Current function (type of traffic generated by the loopback thread) */ -#define GB_LOOPBACK_FN_NONE 0x00 -#define GB_LOOPBACK_FN_PING 0x01 -#define GB_LOOPBACK_FN_XFER 0x02 -#define GB_LOOPBACK_FN_COUNT 0x03 - #define GB_LOOPBACK_MS_WAIT_MAX 1000 #define GB_LOOPBACK_SIZE_MAX SZ_4K @@ -117,10 +111,16 @@ static DEVICE_ATTR_RW(field) static void gb_loopback_reset_stats(struct gb_loopback *gb); static void gb_loopback_check_attr(struct gb_loopback *gb) { + switch (gb->type) { + case GB_LOOPBACK_TYPE_PING: + case GB_LOOPBACK_TYPE_TRANSFER: + break; + default: + gb->type = 0; + break; + } if (gb->ms_wait > GB_LOOPBACK_MS_WAIT_MAX) gb->ms_wait = GB_LOOPBACK_MS_WAIT_MAX; - if (gb->type >= GB_LOOPBACK_FN_COUNT) - gb->type = GB_LOOPBACK_FN_NONE; if (gb->size > GB_LOOPBACK_SIZE_MAX) gb->size = GB_LOOPBACK_SIZE_MAX; gb->error = 0; @@ -337,13 +337,13 @@ static int gb_loopback_fn(void *data) struct gb_loopback *gb = (struct gb_loopback *)data; while (!kthread_should_stop()) { - if (gb->type == GB_LOOPBACK_FN_NONE) { + if (!gb->type) { msleep(1000); continue; } - if (gb->type == GB_LOOPBACK_FN_PING) + if (gb->type == GB_LOOPBACK_TYPE_PING) error = gb_loopback_ping(gb, &tlat); - else if (gb->type == GB_LOOPBACK_FN_XFER) + else if (gb->type == GB_LOOPBACK_TYPE_TRANSFER) error = gb_loopback_transfer(gb, &tlat, gb->size); if (error) gb->error++;