diff options
author | Bram Moolenaar <Bram@vim.org> | 2012-06-29 15:51:30 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2012-06-29 15:51:30 +0200 |
commit | 11b73d668f6209acbe06988a804028c5c86799d2 (patch) | |
tree | befc146fa851f6e6ad217701d02b65fb8ee19b46 | |
parent | 96b7ca5142d72d2c8e79d15f9c38f41d6657be40 (diff) | |
download | vim-git-11b73d668f6209acbe06988a804028c5c86799d2.tar.gz |
updated for version 7.3.577v7.3.577
Problem: Size of memory does not fit in 32 bit unsigned.
Solution: Use Kbyte instead of byte. Call GlobalMemoryStatusEx() instead of
GlobalMemoryStatus() when available.
-rw-r--r-- | src/misc2.c | 3 | ||||
-rw-r--r-- | src/option.c | 6 | ||||
-rw-r--r-- | src/os_amiga.c | 6 | ||||
-rw-r--r-- | src/os_msdos.c | 6 | ||||
-rw-r--r-- | src/os_win16.c | 4 | ||||
-rw-r--r-- | src/os_win32.c | 21 | ||||
-rw-r--r-- | src/version.c | 2 |
7 files changed, 31 insertions, 17 deletions
diff --git a/src/misc2.c b/src/misc2.c index d62c771cd..5d60954be 100644 --- a/src/misc2.c +++ b/src/misc2.c @@ -815,6 +815,7 @@ vim_mem_profile_dump() #else # define KEEP_ROOM (2 * 8192L) #endif +#define KEEP_ROOM_KB (KEEP_ROOM / 1024L) /* * Note: if unsigned is 16 bits we can only allocate up to 64K with alloc(). @@ -940,7 +941,7 @@ lalloc(size, message) allocated = 0; # endif /* 3. check for available memory: call mch_avail_mem() */ - if (mch_avail_mem(TRUE) < KEEP_ROOM && !releasing) + if (mch_avail_mem(TRUE) < KEEP_ROOM_KB && !releasing) { free((char *)p); /* System is low... no go! */ p = NULL; diff --git a/src/option.c b/src/option.c index 9acb270f1..308d7a81f 100644 --- a/src/option.c +++ b/src/option.c @@ -3154,7 +3154,7 @@ set_init_1() { #ifdef HAVE_AVAIL_MEM /* Use amount of memory available at this moment. */ - n = (mch_avail_mem(FALSE) >> 11); + n = (mch_avail_mem(FALSE) >> 1); #else # ifdef HAVE_TOTAL_MEM /* Use amount of memory available to Vim. */ @@ -6702,7 +6702,7 @@ did_set_string_option(opt_idx, varp, new_value_alloced, oldval, errbuf, { for (s = *varp; *s;) { - while(*s == ',' || *s == ' ') + while (*s == ',' || *s == ' ') s++; if (!*s) break; @@ -7391,7 +7391,7 @@ check_clipboard_option() new_unnamed |= CLIP_UNNAMED; p += 7; } - else if (STRNCMP(p, "unnamedplus", 11) == 0 + else if (STRNCMP(p, "unnamedplus", 11) == 0 && (p[11] == ',' || p[11] == NUL)) { new_unnamed |= CLIP_UNNAMED_PLUS; diff --git a/src/os_amiga.c b/src/os_amiga.c index d84af4ce1..e2b157949 100644 --- a/src/os_amiga.c +++ b/src/os_amiga.c @@ -191,16 +191,16 @@ mch_char_avail() } /* - * Return amount of memory still available. + * Return amount of memory still available in Kbyte. */ long_u mch_avail_mem(special) int special; { #ifdef __amigaos4__ - return (long_u)AvailMem(MEMF_ANY); + return (long_u)AvailMem(MEMF_ANY) >> 10; #else - return (long_u)AvailMem(special ? (long)MEMF_CHIP : (long)MEMF_ANY); + return (long_u)(AvailMem(special ? (long)MEMF_CHIP : (long)MEMF_ANY)) >> 10; #endif } diff --git a/src/os_msdos.c b/src/os_msdos.c index 3449d23b9..2d1cf73dd 100644 --- a/src/os_msdos.c +++ b/src/os_msdos.c @@ -550,15 +550,15 @@ mch_update_cursor(void) #endif /* - * Return amount of memory currently available. + * Return amount of memory currently available in Kbyte. */ long_u mch_avail_mem(int special) { #ifdef DJGPP - return _go32_dpmi_remaining_virtual_memory(); + return _go32_dpmi_remaining_virtual_memory() >> 10; #else - return coreleft(); + return coreleft() >> 10; #endif } diff --git a/src/os_win16.c b/src/os_win16.c index 0be6c6316..b620149e7 100644 --- a/src/os_win16.c +++ b/src/os_win16.c @@ -379,13 +379,13 @@ mch_breakcheck() /* - * How much memory is available? + * How much memory is available in Kbyte? */ long_u mch_avail_mem( int special) { - return GetFreeSpace(0); + return GetFreeSpace(0) >> 10; } diff --git a/src/os_win32.c b/src/os_win32.c index c0434dbda..af1232eab 100644 --- a/src/os_win32.c +++ b/src/os_win32.c @@ -4992,18 +4992,29 @@ mch_breakcheck(void) /* - * How much memory is available? + * How much memory is available in Kbyte? * Return sum of available physical and page file memory. */ /*ARGSUSED*/ long_u mch_avail_mem(int special) { - MEMORYSTATUS ms; + if (g_PlatformId != VER_PLATFORM_WIN32_NT) + { + MEMORYSTATUS ms; + + ms.dwLength = sizeof(MEMORYSTATUS); + GlobalMemoryStatus(&ms); + return (long_u)((ms.dwAvailPhys + ms.dwAvailPageFile) >> 10); + } + else + { + MEMORYSTATUSEX ms; - ms.dwLength = sizeof(MEMORYSTATUS); - GlobalMemoryStatus(&ms); - return (long_u) (ms.dwAvailPhys + ms.dwAvailPageFile); + ms.dwLength = sizeof(MEMORYSTATUSEX); + GlobalMemoryStatusEx(&ms); + return (long_u)((ms.ullAvailPhys + ms.ullAvailPageFile) >> 10); + } } #ifdef FEAT_MBYTE diff --git a/src/version.c b/src/version.c index 646d223bd..58bb4732c 100644 --- a/src/version.c +++ b/src/version.c @@ -715,6 +715,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 577, +/**/ 576, /**/ 575, |