From 1fcc0973449c576b120386dc0b044348336ec8c8 Mon Sep 17 00:00:00 2001 From: Joshua Warner Date: Mon, 16 Mar 2015 15:32:50 -0600 Subject: [PATCH] use size_t instead of unsigned in a bunch of appropriate places This would theoretically break compatibility with apps using embedded classpaths, on big-endian architectures - because of the size type extension. However, we don't currently support any big-endian architectures, so it shouldn't be a problem. --- README.md | 6 +-- include/avian/system/system.h | 6 +-- src/avian/classpath-common.h | 6 +-- src/avian/finder.h | 14 +++---- src/avian/lzma.h | 8 ++-- src/avian/machine.h | 2 +- src/boot-javahome.cpp | 2 +- src/boot.cpp | 6 +-- src/finder.cpp | 54 +++++++++++++------------- src/lzma-decode.cpp | 8 ++-- src/machine.cpp | 6 +-- src/main.cpp | 8 ++-- src/system/posix.cpp | 4 +- src/system/windows.cpp | 4 +- src/tools/bootimage-generator/main.cpp | 8 ++-- 15 files changed, 71 insertions(+), 71 deletions(-) diff --git a/README.md b/README.md index 923d5195ca..25ab033736 100644 --- a/README.md +++ b/README.md @@ -454,7 +454,7 @@ setting the boot classpath to "[bootJar]". extern const uint8_t SYMBOL(end)[]; EXPORT const uint8_t* - bootJar(unsigned* size) + bootJar(size_t* size) { *size = SYMBOL(end) - SYMBOL(start); return SYMBOL(start); @@ -682,7 +682,7 @@ containing them. See the previous example for instructions. extern const uint8_t BOOTIMAGE_BIN(end)[]; EXPORT const uint8_t* - bootimageBin(unsigned* size) + bootimageBin(size_t* size) { *size = BOOTIMAGE_BIN(end) - BOOTIMAGE_BIN(start); return BOOTIMAGE_BIN(start); @@ -692,7 +692,7 @@ containing them. See the previous example for instructions. extern const uint8_t CODEIMAGE_BIN(end)[]; EXPORT const uint8_t* - codeimageBin(unsigned* size) + codeimageBin(size_t* size) { *size = CODEIMAGE_BIN(end) - CODEIMAGE_BIN(start); return CODEIMAGE_BIN(start); diff --git a/include/avian/system/system.h b/include/avian/system/system.h index b422c42e12..c1f1dc1489 100644 --- a/include/avian/system/system.h +++ b/include/avian/system/system.h @@ -111,7 +111,7 @@ class System : public avian::util::Aborter { }; virtual bool success(Status) = 0; - virtual void* tryAllocate(unsigned sizeInBytes) = 0; + virtual void* tryAllocate(size_t sizeInBytes) = 0; virtual void free(const void* p) = 0; virtual Status attach(Runnable*) = 0; virtual Status start(Runnable*) = 0; @@ -123,7 +123,7 @@ class System : public avian::util::Aborter { = 0; virtual Status map(Region**, const char* name) = 0; - virtual FileType stat(const char* name, unsigned* length) = 0; + virtual FileType stat(const char* name, size_t* length) = 0; virtual Status open(Directory**, const char* name) = 0; virtual const char* libraryPrefix() = 0; virtual const char* librarySuffix() = 0; @@ -138,7 +138,7 @@ class System : public avian::util::Aborter { virtual void dispose() = 0; }; -inline void* allocate(System* s, unsigned size) +inline void* allocate(System* s, size_t size) { void* p = s->tryAllocate(size); if (p == 0) diff --git a/src/avian/classpath-common.h b/src/avian/classpath-common.h index 6a5bae67c5..85815cbb76 100644 --- a/src/avian/classpath-common.h +++ b/src/avian/classpath-common.h @@ -648,7 +648,7 @@ void intercept(Thread* t, } } -Finder* getFinder(Thread* t, const char* name, unsigned nameLength) +Finder* getFinder(Thread* t, const char* name, size_t nameLength) { ACQUIRE(t, t->m->referenceLock); @@ -668,10 +668,10 @@ Finder* getFinder(Thread* t, const char* name, unsigned nameLength) reinterpret_cast(n->body().begin())); if (p) { - uint8_t* (*function)(unsigned*); + uint8_t* (*function)(size_t*); memcpy(&function, &p, BytesPerWord); - unsigned size; + size_t size = 0; uint8_t* data = function(&size); if (data) { Finder* f = makeFinder(t->m->system, t->m->heap, data, size); diff --git a/src/avian/finder.h b/src/avian/finder.h index c7d45fff03..133f1127ee 100644 --- a/src/avian/finder.h +++ b/src/avian/finder.h @@ -126,8 +126,8 @@ inline const uint8_t* endOfEntry(const uint8_t* p) inline bool readLine(const uint8_t* base, unsigned total, - unsigned* start, - unsigned* length) + size_t* start, + size_t* length) { const uint8_t* p = base + *start; const uint8_t* end = base + total; @@ -147,7 +147,7 @@ class Finder { public: class IteratorImp { public: - virtual const char* next(unsigned* size) = 0; + virtual const char* next(size_t* size) = 0; virtual void dispose() = 0; }; @@ -171,7 +171,7 @@ class Finder { return current != 0; } - const char* next(unsigned* size) + const char* next(size_t* size) { if (hasMore()) { *size = currentSize; @@ -185,13 +185,13 @@ class Finder { IteratorImp* it; const char* current; - unsigned currentSize; + size_t currentSize; }; virtual IteratorImp* iterator() = 0; virtual System::Region* find(const char* name) = 0; virtual System::FileType stat(const char* name, - unsigned* length, + size_t* length, bool tryDirectory = false) = 0; virtual const char* urlPrefix(const char* name) = 0; virtual const char* nextUrlPrefix(const char* name, void*& finderElementPtr) @@ -209,7 +209,7 @@ AVIAN_EXPORT Finder* makeFinder(System* s, Finder* makeFinder(System* s, avian::util::Alloc* a, const uint8_t* jarData, - unsigned jarLength); + size_t jarLength); } // namespace vm diff --git a/src/avian/lzma.h b/src/avian/lzma.h index 2c76c827b4..a9c6baa545 100644 --- a/src/avian/lzma.h +++ b/src/avian/lzma.h @@ -24,14 +24,14 @@ namespace vm { uint8_t* decodeLZMA(System* s, avian::util::Alloc* a, uint8_t* in, - unsigned inSize, - unsigned* outSize); + size_t inSize, + size_t* outSize); uint8_t* encodeLZMA(System* s, avian::util::Alloc* a, uint8_t* in, - unsigned inSize, - unsigned* outSize); + size_t inSize, + size_t* outSize); } // namespace vm diff --git a/src/avian/machine.h b/src/avian/machine.h index 52eca8b282..f509758960 100644 --- a/src/avian/machine.h +++ b/src/avian/machine.h @@ -1062,7 +1062,7 @@ class Machine { JNIEnvVTable jniEnvVTable; uintptr_t* heapPool[ThreadHeapPoolSize]; unsigned heapPoolIndex; - unsigned bootimageSize; + size_t bootimageSize; }; void printTrace(Thread* t, GcThrowable* exception); diff --git a/src/boot-javahome.cpp b/src/boot-javahome.cpp index 189282b8f4..026910ede6 100644 --- a/src/boot-javahome.cpp +++ b/src/boot-javahome.cpp @@ -22,7 +22,7 @@ extern "C" { extern const uint8_t SYMBOL(start)[]; extern const uint8_t SYMBOL(end)[]; -AVIAN_EXPORT const uint8_t* javahomeJar(unsigned* size) +AVIAN_EXPORT const uint8_t* javahomeJar(size_t* size) { *size = SYMBOL(end) - SYMBOL(start); return SYMBOL(start); diff --git a/src/boot.cpp b/src/boot.cpp index 5ab6d374da..3849c9eed0 100644 --- a/src/boot.cpp +++ b/src/boot.cpp @@ -33,7 +33,7 @@ extern "C" { extern const uint8_t BOOTIMAGE_SYMBOL(start)[]; extern const uint8_t BOOTIMAGE_SYMBOL(end)[]; -AVIAN_EXPORT const uint8_t* bootimageBin(unsigned* size) +AVIAN_EXPORT const uint8_t* bootimageBin(size_t* size) { *size = BOOTIMAGE_SYMBOL(end) - BOOTIMAGE_SYMBOL(start); return BOOTIMAGE_SYMBOL(start); @@ -42,7 +42,7 @@ AVIAN_EXPORT const uint8_t* bootimageBin(unsigned* size) extern const uint8_t CODEIMAGE_SYMBOL(start)[]; extern const uint8_t CODEIMAGE_SYMBOL(end)[]; -AVIAN_EXPORT const uint8_t* codeimageBin(unsigned* size) +AVIAN_EXPORT const uint8_t* codeimageBin(size_t* size) { *size = CODEIMAGE_SYMBOL(end) - CODEIMAGE_SYMBOL(start); return CODEIMAGE_SYMBOL(start); @@ -65,7 +65,7 @@ extern "C" { extern const uint8_t SYMBOL(start)[]; extern const uint8_t SYMBOL(end)[]; -AVIAN_EXPORT const uint8_t* classpathJar(unsigned* size) +AVIAN_EXPORT const uint8_t* classpathJar(size_t* size) { *size = SYMBOL(end) - SYMBOL(start); return SYMBOL(start); diff --git a/src/finder.cpp b/src/finder.cpp index a3c1ba4ce6..e16df51184 100644 --- a/src/finder.cpp +++ b/src/finder.cpp @@ -32,7 +32,7 @@ class Element { public: class Iterator { public: - virtual const char* next(unsigned* size) = 0; + virtual const char* next(size_t* size) = 0; virtual void dispose() = 0; }; @@ -43,7 +43,7 @@ class Element { virtual Iterator* iterator() = 0; virtual System::Region* find(const char* name) = 0; virtual System::FileType stat(const char* name, - unsigned* length, + size_t* length, bool tryDirectory) = 0; virtual const char* urlPrefix() = 0; virtual const char* sourceUrl() = 0; @@ -70,7 +70,7 @@ class DirectoryElement : public Element { } } - virtual const char* next(unsigned* size) + virtual const char* next(size_t* size) { if (it) { const char* v = it->next(size); @@ -90,7 +90,7 @@ class DirectoryElement : public Element { for (const char* v = directory->next(); v; v = directory->next()) { if (v[0] != '.') { last = append(allocator, name, "/", v); - unsigned length; + size_t length; if (s->stat(last, &length) == System::TypeDirectory) { it = new (allocator->allocate(sizeof(Iterator))) Iterator(s, allocator, last, skip); @@ -157,7 +157,7 @@ class DirectoryElement : public Element { } } - virtual System::FileType stat(const char* name, unsigned* length, bool) + virtual System::FileType stat(const char* name, size_t* length, bool) { const char* file = append(allocator, this->name, "/", name); System::FileType type = s->stat(file, length); @@ -344,7 +344,7 @@ class JarIndex { List* findNode(const char* name) { - unsigned length = strlen(name); + size_t length = strlen(name); unsigned i = hash(name) & (capacity - 1); for (List* n = table[i]; n; n = n->next) { const uint8_t* p = n->item.entry; @@ -403,7 +403,7 @@ class JarIndex { return 0; } - System::FileType stat(const char* name, unsigned* length, bool tryDirectory) + System::FileType stat(const char* name, size_t* length, bool tryDirectory) { List* node = findNode(name); if (node) { @@ -413,7 +413,7 @@ class JarIndex { *length = 0; // try again with '/' appended - unsigned length = strlen(name); + size_t length = strlen(name); RUNTIME_ARRAY(char, n, length + 2); memcpy(RUNTIME_ARRAY_BODY(n), name, length); RUNTIME_ARRAY_BODY(n)[length] = '/'; @@ -455,7 +455,7 @@ class JarElement : public Element { { } - virtual const char* next(unsigned* size) + virtual const char* next(size_t* size) { if (position < index->position) { List* n = index->nodes + (position++); @@ -548,7 +548,7 @@ class JarElement : public Element { } virtual System::FileType stat(const char* name, - unsigned* length, + size_t* length, bool tryDirectory) { init(); @@ -629,16 +629,16 @@ class BuiltinElement : public JarElement { void* p = library->resolve(symbolName); if (p) { - uint8_t* (*function)(unsigned*); + uint8_t* (*function)(size_t*); memcpy(&function, &p, BytesPerWord); - unsigned size; + size_t size = 0; uint8_t* data = function(&size); if (data) { bool freePointer; if (lzma) { #ifdef AVIAN_USE_LZMA - unsigned outSize; + size_t outSize; data = decodeLZMA(s, allocator, data, size, &outSize); size = outSize; freePointer = true; @@ -751,8 +751,8 @@ void addTokens(System* s, bool continuationLine(const uint8_t* base, unsigned total, - unsigned* start, - unsigned* length) + size_t* start, + size_t* length) { return readLine(base, total, start, length) and *length > 0 and base[*start] == ' '; @@ -778,8 +778,8 @@ void addJar(System* s, System::Region* region = e->find("META-INF/MANIFEST.MF"); if (region) { - unsigned start = 0; - unsigned length; + size_t start = 0; + size_t length; while (readLine(region->start(), region->length(), &start, &length)) { unsigned multilineTotal = 0; @@ -789,8 +789,8 @@ void addJar(System* s, reinterpret_cast(region->start() + start), PrefixLength) == 0) { { - unsigned nextStart = start + length; - unsigned nextLength; + size_t nextStart = start + length; + size_t nextLength; while (continuationLine( region->start(), region->length(), &nextStart, &nextLength)) { multilineTotal += nextLength; @@ -810,8 +810,8 @@ void addJar(System* s, unsigned offset = lineLength; { - unsigned nextStart = start + length; - unsigned nextLength; + size_t nextStart = start + length; + size_t nextLength; while (continuationLine( region->start(), region->length(), &nextStart, &nextLength)) { unsigned continuationLength = nextLength - 1; @@ -880,7 +880,7 @@ void add(System* s, memcpy(name, token, tokenLength); name[tokenLength] = 0; - unsigned length; + size_t length; switch (s->stat(name, &length)) { case System::TypeFile: { addJar(s, first, last, allocator, name, bootLibrary); @@ -934,7 +934,7 @@ class MyIterator : public Finder::IteratorImp { { } - virtual const char* next(unsigned* size) + virtual const char* next(size_t* size) { while (it) { const char* v = it->next(size); @@ -1010,7 +1010,7 @@ class MyFinder : public Finder { } virtual System::FileType stat(const char* name, - unsigned* length, + size_t* length, bool tryDirectory) { for (Element* e = path_; e; e = e->next) { @@ -1034,7 +1034,7 @@ class MyFinder : public Finder { Element*& e = reinterpret_cast(finderElementPtr); e = e ? e->next : path_; for (; e; e = e->next) { - unsigned length; + size_t length; System::FileType type = e->stat(name, &length, true); if (type != System::TypeDoesNotExist) { return e->urlPrefix(); @@ -1047,7 +1047,7 @@ class MyFinder : public Finder { virtual const char* sourceUrl(const char* name) { for (Element* e = path_; e; e = e->next) { - unsigned length; + size_t length; System::FileType type = e->stat(name, &length, true); if (type != System::TypeDoesNotExist) { return e->sourceUrl(); @@ -1096,7 +1096,7 @@ AVIAN_EXPORT Finder* makeFinder(System* s, Finder* makeFinder(System* s, Alloc* a, const uint8_t* jarData, - unsigned jarLength) + size_t jarLength) { return new (a->allocate(sizeof(MyFinder))) MyFinder(s, a, jarData, jarLength); } diff --git a/src/lzma-decode.cpp b/src/lzma-decode.cpp index ac19585171..e94253e340 100644 --- a/src/lzma-decode.cpp +++ b/src/lzma-decode.cpp @@ -29,11 +29,11 @@ namespace vm { uint8_t* decodeLZMA(System* s, avian::util::Alloc* a, uint8_t* in, - unsigned inSize, - unsigned* outSize) + size_t inSize, + size_t* outSize) { - const unsigned PropHeaderSize = 5; - const unsigned HeaderSize = 13; + const size_t PropHeaderSize = 5; + const size_t HeaderSize = 13; int32_t outSize32 = read4(in + PropHeaderSize); expect(s, outSize32 >= 0); diff --git a/src/machine.cpp b/src/machine.cpp index 18f64bc424..b133856937 100644 --- a/src/machine.cpp +++ b/src/machine.cpp @@ -3810,10 +3810,10 @@ void Thread::init() void* imagep = m->libraries->resolve(symbolName); if (imagep) { - uint8_t* (*imageFunction)(unsigned*); + uint8_t* (*imageFunction)(size_t*); memcpy(&imageFunction, &imagep, BytesPerWord); - unsigned size; + size_t size = 0; uint8_t* imageBytes = imageFunction(&size); if (lzma) { #ifdef AVIAN_USE_LZMA @@ -3830,7 +3830,7 @@ void Thread::init() if (codeFunctionName) { void* codep = m->libraries->resolve(codeFunctionName); if (codep) { - uint8_t* (*codeFunction)(unsigned*); + uint8_t* (*codeFunction)(size_t*); memcpy(&codeFunction, &codep, BytesPerWord); code = codeFunction(&size); diff --git a/src/main.cpp b/src/main.cpp index 5f3daac11d..dd6b616666 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -91,8 +91,8 @@ const char* mainClass(const char* jar) System::Region* region = finder->find("META-INF/MANIFEST.MF"); if (region) { - unsigned start = 0; - unsigned length; + size_t start = 0; + size_t length; while (readLine(region->start(), region->length(), &start, &length)) { const unsigned PrefixLength = 12; if (strncasecmp("Main-Class: ", @@ -226,8 +226,8 @@ int main(int ac, const char** av) #define CLASSPATH_PROPERTY "-Djava.class.path=" - unsigned classpathSize = strlen(classpath); - unsigned classpathPropertyBufferSize = sizeof(CLASSPATH_PROPERTY) + size_t classpathSize = strlen(classpath); + size_t classpathPropertyBufferSize = sizeof(CLASSPATH_PROPERTY) + classpathSize; RUNTIME_ARRAY(char, classpathPropertyBuffer, classpathPropertyBufferSize); diff --git a/src/system/posix.cpp b/src/system/posix.cpp index 9a454318ea..256f479bee 100644 --- a/src/system/posix.cpp +++ b/src/system/posix.cpp @@ -654,7 +654,7 @@ class MySystem : public System { return sigaction(signals[index], &sa, oldHandlers + index) == 0; } - virtual void* tryAllocate(unsigned sizeInBytes) + virtual void* tryAllocate(size_t sizeInBytes) { return malloc(sizeInBytes); } @@ -808,7 +808,7 @@ class MySystem : public System { return status; } - virtual FileType stat(const char* name, unsigned* length) + virtual FileType stat(const char* name, size_t* length) { #ifdef __FreeBSD__ // Now the hack below causes the error "Dereferencing type-punned diff --git a/src/system/windows.cpp b/src/system/windows.cpp index 52ab33a9a0..041c20995f 100644 --- a/src/system/windows.cpp +++ b/src/system/windows.cpp @@ -664,7 +664,7 @@ class MySystem : public System { assertT(this, mutex); } - virtual void* tryAllocate(unsigned sizeInBytes) + virtual void* tryAllocate(size_t sizeInBytes) { return malloc(sizeInBytes); } @@ -862,7 +862,7 @@ class MySystem : public System { return status; } - virtual FileType stat(const char* name, unsigned* length) + virtual FileType stat(const char* name, size_t* length) { size_t nameLen = strlen(name) * 2; RUNTIME_ARRAY(wchar_t, wideName, nameLen + 1); diff --git a/src/tools/bootimage-generator/main.cpp b/src/tools/bootimage-generator/main.cpp index 968d9f35f5..a0d3db5f09 100644 --- a/src/tools/bootimage-generator/main.cpp +++ b/src/tools/bootimage-generator/main.cpp @@ -348,13 +348,13 @@ GcTriple* makeCodeImage(Thread* t, roots(t)->bootLoader()->as(t)->finder()); for (Finder::Iterator it(finder); it.hasMore();) { - unsigned nameSize = 0; + size_t nameSize = 0; const char* name = it.next(&nameSize); if (endsWith(".class", name, nameSize) and (className == 0 or strncmp(name, className, nameSize - 6) == 0)) { if (false) { - fprintf(stderr, "pass 1 %.*s\n", nameSize - 6, name); + fprintf(stderr, "pass 1 %.*s\n", (int)nameSize - 6, name); } GcClass* c = resolveSystemClass(t, @@ -686,13 +686,13 @@ GcTriple* makeCodeImage(Thread* t, } for (Finder::Iterator it(finder); it.hasMore();) { - unsigned nameSize = 0; + size_t nameSize = 0; const char* name = it.next(&nameSize); if (endsWith(".class", name, nameSize) and (className == 0 or strncmp(name, className, nameSize - 6) == 0)) { if (false) { - fprintf(stderr, "pass 2 %.*s\n", nameSize - 6, name); + fprintf(stderr, "pass 2 %.*s\n", (int)nameSize - 6, name); } GcClass* c = 0; PROTECT(t, c);