mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	bpftool: Fix a bug in subskeleton code generation
Compiled with clang by adding LLVM=1 both kernel and selftests/bpf
build, I hit the following compilation error:
In file included from /.../tools/testing/selftests/bpf/prog_tests/subskeleton.c:6:
  ./test_subskeleton_lib.subskel.h:168:6: error: variable 'err' is used uninitialized whenever
      'if' condition is true [-Werror,-Wsometimes-uninitialized]
          if (!s->progs)
              ^~~~~~~~~
  ./test_subskeleton_lib.subskel.h:181:11: note: uninitialized use occurs here
          errno = -err;
                   ^~~
  ./test_subskeleton_lib.subskel.h:168:2: note: remove the 'if' if its condition is always false
          if (!s->progs)
          ^~~~~~~~~~~~~~
The compilation error is triggered by the following code
        ...
        int err;
        obj = (struct test_subskeleton_lib *)calloc(1, sizeof(*obj));
        if (!obj) {
                errno = ENOMEM;
                goto err;
        }
        ...
  err:
        test_subskeleton_lib__destroy(obj);
        errno = -err;
        ...
in test_subskeleton_lib__open(). The 'err' is not initialized, yet it
is used in 'errno = -err' later.
The fix is to remove 'errno = -err' since errno has been set properly
in all incoming branches.
Fixes: 00389c58ff ("bpftool: Add support for subskeletons")
Signed-off-by: Yonghong Song <yhs@fb.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Link: https://lore.kernel.org/bpf/20220320032009.3106133-1-yhs@fb.com
			
			
This commit is contained in:
		
							parent
							
								
									e581094167
								
							
						
					
					
						commit
						f97b8b9bd6
					
				
					 1 changed files with 0 additions and 1 deletions
				
			
		| 
						 | 
					@ -1538,7 +1538,6 @@ static int do_subskeleton(int argc, char **argv)
 | 
				
			||||||
			return obj;					    \n\
 | 
								return obj;					    \n\
 | 
				
			||||||
		err:							    \n\
 | 
							err:							    \n\
 | 
				
			||||||
			%1$s__destroy(obj);				    \n\
 | 
								%1$s__destroy(obj);				    \n\
 | 
				
			||||||
			errno = -err;					    \n\
 | 
					 | 
				
			||||||
			return NULL;					    \n\
 | 
								return NULL;					    \n\
 | 
				
			||||||
		}							    \n\
 | 
							}							    \n\
 | 
				
			||||||
									    \n\
 | 
														    \n\
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue