nginx + gcc 4.6 = warnings

Igor Sysoev igor на sysoev.ru
Сб Апр 23 20:56:37 MSD 2011


On Sat, Apr 23, 2011 at 08:47:25PM +0400, Валентин Бартенев wrote:
> Добрый вечер.
> 
> Если собирать без debug, то свежий gcc, как мне кажется, вполне справедливо 
> замечает:
> src/core/ngx_resolver.c: In function ‘ngx_resolver_process_ptr’:
> src/core/ngx_resolver.c:1425:43: error: variable ‘qclass’ set but not used [-
> Werror=unused-but-set-variable]
> src/core/ngx_resolver.c:1425:36: error: variable ‘qtype’ set but not used [-
> Werror=unused-but-set-variable]
> 
> вроде бы ничего криминального, но в сочетании с -Werror это приводит к 
> останову сборки: cc1: all warnings being treated as errors
> 
> p. s.
> nginx 1.0.0
> gcc 4.6.0 20110415

Патч.


-- 
Igor Sysoev
-------------- next part --------------
Index: src/event/modules/ngx_epoll_module.c
===================================================================
--- src/event/modules/ngx_epoll_module.c	(revision 3902)
+++ src/event/modules/ngx_epoll_module.c	(working copy)
@@ -518,7 +518,6 @@
     ngx_int_t          instance, i;
     ngx_uint_t         level;
     ngx_err_t          err;
-    ngx_log_t         *log;
     ngx_event_t       *rev, *wev, **queue;
     ngx_connection_t  *c;
 
@@ -565,8 +564,6 @@
 
     ngx_mutex_lock(ngx_posted_events_mutex);
 
-    log = cycle->log;
-
     for (i = 0; i < events; i++) {
         c = event_list[i].data.ptr;
 
@@ -587,25 +584,21 @@
             continue;
         }
 
-#if (NGX_DEBUG0)
-        log = c->log ? c->log : cycle->log;
-#endif
-
         revents = event_list[i].events;
 
-        ngx_log_debug3(NGX_LOG_DEBUG_EVENT, log, 0,
+        ngx_log_debug3(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
                        "epoll: fd:%d ev:%04XD d:%p",
                        c->fd, revents, event_list[i].data.ptr);
 
         if (revents & (EPOLLERR|EPOLLHUP)) {
-            ngx_log_debug2(NGX_LOG_DEBUG_EVENT, log, 0,
+            ngx_log_debug2(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
                            "epoll_wait() error on fd:%d ev:%04XD",
                            c->fd, revents);
         }
 
 #if 0
         if (revents & ~(EPOLLIN|EPOLLOUT|EPOLLERR|EPOLLHUP)) {
-            ngx_log_error(NGX_LOG_ALERT, log, 0,
+            ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
                           "strange epoll_wait() events fd:%d ev:%04XD",
                           c->fd, revents);
         }
Index: src/core/ngx_resolver.c
===================================================================
--- src/core/ngx_resolver.c	(revision 3902)
+++ src/core/ngx_resolver.c	(working copy)
@@ -1422,7 +1422,7 @@
     in_addr_t             addr;
     ngx_int_t             digit;
     ngx_str_t             name;
-    ngx_uint_t            i, mask, qtype, qclass, qident;
+    ngx_uint_t            i, mask, qident;
     ngx_resolver_an_t    *an;
     ngx_resolver_ctx_t   *ctx, *next;
     ngx_resolver_node_t  *rn;
@@ -1514,12 +1514,12 @@
 
     an = (ngx_resolver_an_t *) &buf[i + 2];
 
-    qtype = (an->type_hi << 8) + an->type_lo;
-    qclass = (an->class_hi << 8) + an->class_lo;
     len = (an->len_hi << 8) + an->len_lo;
 
     ngx_log_debug3(NGX_LOG_DEBUG_CORE, r->log, 0,
-                  "resolver qt:%ui cl:%ui len:%uz", qtype, qclass, len);
+                  "resolver qt:%ui cl:%ui len:%uz",
+                  (an->type_hi << 8) + an->type_lo,
+                  (an->class_hi << 8) + an->class_lo, len);
 
     i += 2 + sizeof(ngx_resolver_an_t);
 


Подробная информация о списке рассылки nginx-ru