Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d79f56b5 authored by David Kershner's avatar David Kershner Committed by Greg Kroah-Hartman
Browse files

staging: unisys: visorbus: cleanup gotos in parser_init_byte_stream



Clean up the goto in parser_init_byte_stream and make the goto section
the error case.

Signed-off-by: default avatarDavid Kershner <david.kershner@unisys.com>
Signed-off-by: default avatarTimothy Sell <timothy.sell@unisys.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent dde29996
Loading
Loading
Loading
Loading
+14 −25
Original line number Original line Diff line number Diff line
@@ -359,8 +359,7 @@ static struct parser_context *
parser_init_byte_stream(u64 addr, u32 bytes, bool local, bool *retry)
parser_init_byte_stream(u64 addr, u32 bytes, bool local, bool *retry)
{
{
	int allocbytes = sizeof(struct parser_context) + bytes;
	int allocbytes = sizeof(struct parser_context) + bytes;
	struct parser_context *rc = NULL;
	struct parser_context *ctx;
	struct parser_context *ctx = NULL;


	if (retry)
	if (retry)
		*retry = false;
		*retry = false;
@@ -374,15 +373,13 @@ parser_init_byte_stream(u64 addr, u32 bytes, bool local, bool *retry)
	    > MAX_CONTROLVM_PAYLOAD_BYTES) {
	    > MAX_CONTROLVM_PAYLOAD_BYTES) {
		if (retry)
		if (retry)
			*retry = true;
			*retry = true;
		rc = NULL;
		return NULL;
		goto cleanup;
	}
	}
	ctx = kzalloc(allocbytes, GFP_KERNEL | __GFP_NORETRY);
	ctx = kzalloc(allocbytes, GFP_KERNEL | __GFP_NORETRY);
	if (!ctx) {
	if (!ctx) {
		if (retry)
		if (retry)
			*retry = true;
			*retry = true;
		rc = NULL;
		return NULL;
		goto cleanup;
	}
	}


	ctx->allocbytes = allocbytes;
	ctx->allocbytes = allocbytes;
@@ -393,35 +390,27 @@ parser_init_byte_stream(u64 addr, u32 bytes, bool local, bool *retry)
	if (local) {
	if (local) {
		void *p;
		void *p;


		if (addr > virt_to_phys(high_memory - 1)) {
		if (addr > virt_to_phys(high_memory - 1))
			rc = NULL;
			goto err_finish_ctx;
			goto cleanup;
		}
		p = __va((unsigned long)(addr));
		p = __va((unsigned long)(addr));
		memcpy(ctx->data, p, bytes);
		memcpy(ctx->data, p, bytes);
	} else {
	} else {
		void *mapping = memremap(addr, bytes, MEMREMAP_WB);
		void *mapping = memremap(addr, bytes, MEMREMAP_WB);


		if (!mapping) {
		if (!mapping)
			rc = NULL;
			goto err_finish_ctx;
			goto cleanup;
		}
		memcpy(ctx->data, mapping, bytes);
		memcpy(ctx->data, mapping, bytes);
		memunmap(mapping);
		memunmap(mapping);
	}
	}


	ctx->byte_stream = true;
	ctx->byte_stream = true;
	rc = ctx;
cleanup:
	if (rc) {
	controlvm_payload_bytes_buffered += ctx->param_bytes;
	controlvm_payload_bytes_buffered += ctx->param_bytes;
	} else {

		if (ctx) {
	return ctx;

err_finish_ctx:
	parser_done(ctx);
	parser_done(ctx);
			ctx = NULL;
	return NULL;
		}
	}
	return rc;
}
}


static uuid_le
static uuid_le