Closed Bug 818741 Opened 12 years ago Closed 12 years ago

Fix gcc compiler warnings "cast to pointer from integer of different size" in certvfy.c in 64-bit builds

Categories

(NSS :: Libraries, defect, P2)

3.13
defect

Tracking

(Not tracked)

RESOLVED FIXED
3.14.1

People

(Reporter: wtc, Assigned: wtc)

Details

Attachments

(1 file)

Attached patch PatchSplinter Review
When doing a 64-bit build on Linux with gcc 4.4.3, I get the
following compiler warnings in certvfy.c:

gcc -o Linux2.6_x86_64_glibc_PTH_64_DBG.OBJ/certvfy.o -c -g -ansi -D_POSIX_SOURCE -D_BSD_SOURCE -D_XOPEN_SOURCE -fPIC -DLINUX2_1  -Wall -Werror-implicit-function-declaration -Wno-switch -pipe -DLINUX -Dlinux -DHAVE_STRERROR -DXP_UNIX -DDEBUG -UNDEBUG -DDEBUG_wtc -D_REENTRANT -DNSS_ENABLE_ECC -DNSS_ECC_MORE_THAN_SUITE_B -DUSE_UTIL_DIRECTLY -I../../../../dist/Linux2.6_x86_64_glibc_PTH_64_DBG.OBJ/include -I../../../../dist/public/nss -I../../../../dist/private/nss  certvfy.c
certvfy.c: In function ‘cert_VerifyCertChainOld’:
certvfy.c:504: warning: cast to pointer from integer of different size
certvfy.c:568: warning: cast to pointer from integer of different size
certvfy.c:596: warning: cast to pointer from integer of different size
certvfy.c:624: warning: cast to pointer from integer of different size
certvfy.c: In function ‘CERT_VerifyCACertForUsage’:
certvfy.c:839: warning: cast to pointer from integer of different size
certvfy.c:864: warning: cast to pointer from integer of different size
certvfy.c: In function ‘CERT_VerifyCertificate’:
certvfy.c:1160: warning: cast to pointer from integer of different size
certvfy.c:1167: warning: cast to pointer from integer of different size
certvfy.c:1176: warning: cast to pointer from integer of different size
certvfy.c: In function ‘CERT_VerifyCert’:
certvfy.c:1298: warning: cast to pointer from integer of different size
certvfy.c:1302: warning: cast to pointer from integer of different size
certvfy.c:1308: warning: cast to pointer from integer of different size

The attached patch fixes the warning. The fix works by using an intermediate
cast to PRWord, which is an integer type that is the same size as a pointer,
equivalent to the intptr_t type of C99.

I also changed the type of the |error| argument to |long| because NSPR
error code is a signed type. For example, PORT_GetError() returns int:
http://bonsai.mozilla.org/cvsblame.cgi?file=mozilla/security/nss/lib/util/secport.h&rev=1.29&mark=75#75

The |error| argument is ultimately stored in the |error| field of the
CERTVerifyLogNodeStr structure, which is a |long|:
http://bonsai.mozilla.org/cvsblame.cgi?file=mozilla/security/nss/lib/certdb/certt.h&rev=1.57&mark=734,736,738#729
Attachment #689019 - Flags: review?(mark)
Attachment #689019 - Flags: review?(mark) → review+
Patch checked in on the NSS trunk (NSS 3.14.1).

Checking in lib/certdb/certi.h;
/cvsroot/mozilla/security/nss/lib/certdb/certi.h,v  <--  certi.h
new revision: 1.38; previous revision: 1.37
done
Checking in lib/certhigh/certvfy.c;
/cvsroot/mozilla/security/nss/lib/certhigh/certvfy.c,v  <--  certvfy.c
new revision: 1.78; previous revision: 1.77
done
Status: ASSIGNED → RESOLVED
Closed: 12 years ago
Resolution: --- → FIXED
Target Milestone: 3.14.2 → 3.14.1
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Creator:
Created:
Updated:
Size: