mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	protocol-native: improve message debug
This commit is contained in:
		
							parent
							
								
									f792c3f536
								
							
						
					
					
						commit
						1c46dc32f8
					
				
					 1 changed files with 20 additions and 11 deletions
				
			
		| 
						 | 
					@ -122,6 +122,20 @@ struct client_data {
 | 
				
			||||||
	struct protocol_compat_v2 compat_v2;
 | 
						struct protocol_compat_v2 compat_v2;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static void debug_msg(const char *prefix, const struct pw_protocol_native_message *msg, bool hex)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct spa_pod *pod;
 | 
				
			||||||
 | 
						fprintf(stderr, "%s: id:%d op:%d size:%d seq:%d\n", prefix,
 | 
				
			||||||
 | 
								msg->id, msg->opcode, msg->size, msg->seq);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if ((pod = spa_pod_from_data(msg->data, msg->size, 0, msg->size)) != NULL)
 | 
				
			||||||
 | 
							spa_debug_pod(0, NULL, pod);
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							hex = true;
 | 
				
			||||||
 | 
						if (hex)
 | 
				
			||||||
 | 
							spa_debug_mem(0, msg->data, msg->size);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int
 | 
					static int
 | 
				
			||||||
process_messages(struct client_data *data)
 | 
					process_messages(struct client_data *data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -160,11 +174,8 @@ process_messages(struct client_data *data)
 | 
				
			||||||
		pw_log_trace(NAME" %p: got message %d from %u", client->protocol,
 | 
							pw_log_trace(NAME" %p: got message %d from %u", client->protocol,
 | 
				
			||||||
			     msg->opcode, msg->id);
 | 
								     msg->opcode, msg->id);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (debug_messages) {
 | 
							if (debug_messages)
 | 
				
			||||||
			fprintf(stderr, "<<<<<<<<< in: id:%d op:%d size:%d seq:%d\n",
 | 
								debug_msg("<<<<<< in", msg, false);
 | 
				
			||||||
					msg->id, msg->opcode, msg->size, msg->seq);
 | 
					 | 
				
			||||||
		        spa_debug_pod(0, NULL, (struct spa_pod *)msg->data);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		resource = pw_impl_client_find_resource(client, msg->id);
 | 
							resource = pw_impl_client_find_resource(client, msg->id);
 | 
				
			||||||
		if (resource == NULL) {
 | 
							if (resource == NULL) {
 | 
				
			||||||
| 
						 | 
					@ -217,7 +228,7 @@ invalid_message:
 | 
				
			||||||
		     client->protocol, msg->id, msg->opcode, spa_strerror(res));
 | 
							     client->protocol, msg->id, msg->opcode, spa_strerror(res));
 | 
				
			||||||
	pw_resource_errorf(resource, res, "invalid message received id:%u op:%u (%s)",
 | 
						pw_resource_errorf(resource, res, "invalid message received id:%u op:%u (%s)",
 | 
				
			||||||
			msg->id, msg->opcode, spa_strerror(res));
 | 
								msg->id, msg->opcode, spa_strerror(res));
 | 
				
			||||||
	spa_debug_pod(0, NULL, (struct spa_pod *)msg->data);
 | 
						debug_msg("*invalid message*", msg, true);
 | 
				
			||||||
	goto done;
 | 
						goto done;
 | 
				
			||||||
error:
 | 
					error:
 | 
				
			||||||
	pw_log_error(NAME" %p: client error (%s)", client->protocol, spa_strerror(res));
 | 
						pw_log_error(NAME" %p: client error (%s)", client->protocol, spa_strerror(res));
 | 
				
			||||||
| 
						 | 
					@ -619,11 +630,8 @@ process_remote(struct client *impl)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		this->recv_seq = msg->seq;
 | 
							this->recv_seq = msg->seq;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (debug_messages) {
 | 
							if (debug_messages)
 | 
				
			||||||
			fprintf(stderr, "<<<<<<<<< in: id:%d op:%d size:%d seq:%d\n",
 | 
								debug_msg("<<<<<< in", msg, false);
 | 
				
			||||||
					msg->id, msg->opcode, msg->size, msg->seq);
 | 
					 | 
				
			||||||
		        spa_debug_pod(0, NULL, (struct spa_pod *)msg->data);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		proxy = pw_core_find_proxy(this, msg->id);
 | 
							proxy = pw_core_find_proxy(this, msg->id);
 | 
				
			||||||
		if (proxy == NULL || proxy->zombie) {
 | 
							if (proxy == NULL || proxy->zombie) {
 | 
				
			||||||
| 
						 | 
					@ -657,6 +665,7 @@ process_remote(struct client *impl)
 | 
				
			||||||
		if (res < 0) {
 | 
							if (res < 0) {
 | 
				
			||||||
			pw_log_error (NAME" %p: invalid message received %u for %u",
 | 
								pw_log_error (NAME" %p: invalid message received %u for %u",
 | 
				
			||||||
					this, msg->opcode, msg->id);
 | 
										this, msg->opcode, msg->id);
 | 
				
			||||||
 | 
								debug_msg("*invalid*", msg, true);
 | 
				
			||||||
			continue;
 | 
								continue;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue