On 9/7/21 3:52 AM, yla...@apache.org wrote:
> Author: ylavic
> Date: Tue Sep 7 01:52:48 2021
> New Revision: 1893004
>
> URL: http://svn.apache.org/viewvc?rev=1893004&view=rev
> Log:
> mod_unique_id: Follow up to r1892915 and r1893002: Atomic counter.
>
> * modules/metadata/mod_unique_id.c(gen_unique_id):
> Use an atomic 32bit counter to close the race condition, using the lower
> 16 bits for uuencoding still.
>
>
> Modified:
> httpd/httpd/trunk/modules/metadata/mod_unique_id.c
>
> Modified: httpd/httpd/trunk/modules/metadata/mod_unique_id.c
> URL:
> http://svn.apache.org/viewvc/httpd/httpd/trunk/modules/metadata/mod_unique_id.c?rev=1893004&r1=1893003&r2=1893004&view=diff
> ==============================================================================
> --- httpd/httpd/trunk/modules/metadata/mod_unique_id.c (original)
> +++ httpd/httpd/trunk/modules/metadata/mod_unique_id.c Tue Sep 7 01:52:48
> 2021
> @@ -194,16 +212,24 @@ static const char *gen_unique_id(const r
> unique_id_rec foo;
> unsigned char pad[2];
> } paddedbuf;
> + apr_uint32_t counter;
> unsigned char *x,*y;
> int i,j,k;
>
> memcpy(&new_unique_id.root, &cur_unique_id.root, ROOT_SIZE);
> new_unique_id.stamp = htonl((unsigned int)apr_time_sec(r->request_time));
> new_unique_id.thread_index = htonl((unsigned int)r->connection->id);
> - new_unique_id.counter = cur_unique_id.counter++;
> +#ifdef APR_HAS_THREADS
> + if (is_threaded_mpm)
> + counter = apr_atomic_inc32(&cur_unique_counter);
> + else
> +#endif
> + counter = cur_unique_counter++;
>
> - /* Set counter in network byte order for the uuencoded unique id. */
> - new_unique_id.counter = htons(new_unique_id.counter);
> + /* The counter is two bytes for the uuencoded unique id, in network
> + * byte order.
> + */
> + new_unique_id.counter = htons(counter % APR_UINT16_MAX);
Isn't '&' doing the same as '%' here and is more performant?
Regards
RĂ¼diger