Warning: mysqli::__construct(): (HY000/1203): User howardkn already has more than 'max_user_connections' active connections in D:\Inetpub\vhosts\howardknight.net\al.howardknight.net\includes\artfuncs.php on line 21
Failed to connect to MySQL: (1203) User howardkn already has more than 'max_user_connections' active connections
Warning: mysqli::query(): Couldn't fetch mysqli in D:\Inetpub\vhosts\howardknight.net\al.howardknight.net\index.php on line 66
Article <v9kgfe$tcbl$1@dont-email.me>
Deutsch   English   Français   Italiano  
<v9kgfe$tcbl$1@dont-email.me>

View for Bookmarking (what is this?)
Look up another Usenet article

Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: Richard Harnden <richard.nospam@gmail.invalid>
Newsgroups: comp.lang.c
Subject: Re: why does bsearch segfault on custom strcmp when qsort works fine?
Date: Thu, 15 Aug 2024 10:06:53 +0100
Organization: A noiseless patient Spider
Lines: 43
Message-ID: <v9kgfe$tcbl$1@dont-email.me>
References: <UQWdnfwQxtYABSD7nZ2dnZfqnPadnZ2d@brightview.co.uk>
Reply-To: nospam.harnden@invalid.com
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Thu, 15 Aug 2024 11:06:54 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="1493ecad95c00a474ab74fee15fd5ff4";
	logging-data="962933"; mail-complaints-to="abuse@eternal-september.org";	posting-account="U2FsdGVkX19jrpAAYyi0iIB7jd8IL0qoxFiUDE0pVYQ="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:NAf7K0swxp+u2AKlHyrIC6IfGVc=
Content-Language: en-US
In-Reply-To: <UQWdnfwQxtYABSD7nZ2dnZfqnPadnZ2d@brightview.co.uk>

On 15/08/2024 06:56, Mark Summerfield wrote:
> I have a program (complete source at the end) which correctly outputs this:
> 
> ["charlie" "foxtrot" "oscar" "echo" "alpha" "golf" "tango" "delta" "bravo"]
> ["alpha" "bravo" "charlie" "delta" "echo" "foxtrot" "golf" "oscar" "tango"]
> check_array OK
> check_index_found true OK
> check_index_found false OK
> 
> However, if you uncomment the "//#define BUG" line, the output (in gdb) is this:
> 
> (gdb) run
> Starting program: /home/mark/tmp/mycmpstr/mycmpstr
> [Thread debugging using libthread_db enabled]
> Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
> ["charlie" "foxtrot" "oscar" "echo" "alpha" "golf" "tango" "delta" "bravo"]
> ["alpha" "bravo" "charlie" "delta" "echo" "foxtrot" "golf" "oscar" "tango"]
> check_array OK
> 
> Program received signal SIGSEGV, Segmentation fault.
> __strcmp_avx2 () at ../sysdeps/x86_64/multiarch/strcmp-avx2.S:283
> 283	../sysdeps/x86_64/multiarch/strcmp-avx2.S: No such file or directory.
> (gdb) bt
> #0  __strcmp_avx2 () at ../sysdeps/x86_64/multiarch/strcmp-avx2.S:283
> #1  0x00005555555553e0 in mystrcmp (s=0x555555556030, t=0x7fffffffde10) at mycmpstr.c:50
> #2  0x00007ffff7e0a53c in __GI_bsearch (__key=0x555555556030, __base=0x7fffffffddf0,
>      __nmemb=<optimized out>, __size=8, __compar=0x5555555553b7 <mystrcmp>)
>      at ../bits/stdlib-bsearch.h:33
> #3  0x0000555555555317 in main () at mycmpstr.c:30
> 
> The difference is that without BUG defined I use my own binary search,
> but with BUG defined I use bsearch.
> 
> [...]
> 
> int mystrcmp(const void* s, const void* t) {
>      return strcmp(*(const char**)s, *(const char**)t);

You don't need to cast void*s, change that to:
     return strcmp(s, t);

> }
>