Chromium Code Reviews| Index: chrome/installer/mini_installer/mini_installer.cc |
| =================================================================== |
| --- chrome/installer/mini_installer/mini_installer.cc (revision 78547) |
| +++ chrome/installer/mini_installer/mini_installer.cc (working copy) |
| @@ -6,10 +6,10 @@ |
| // installed or upgraded. It is designed to be extremely small (~5KB with no |
| // extra resources linked) and it has two main jobs: |
| // 1) unpack the resources (possibly decompressing some) |
| -// 2) run the real installer (setup.exe) with appropiate flags. |
| +// 2) run the real installer (setup.exe) with appropriate flags. |
| // |
| -// In order to be really small we don't link against the CRT and we define the |
| -// following compiler/linker flags: |
| +// In order to be really small the app doesn't link against the CRT and |
| +// defines the following compiler/linker flags: |
| // EnableIntrinsicFunctions="true" compiler: /Oi |
| // BasicRuntimeChecks="0" |
| // BufferSecurityCheck="false" compiler: /GS- |
| @@ -17,15 +17,8 @@ |
| // IgnoreAllDefaultLibraries="true" linker: /NODEFAULTLIB |
| // OptimizeForWindows98="1" liker: /OPT:NOWIN98 |
| // linker: /SAFESEH:NO |
| -// Also some built-in code that the compiler relies on is not defined so we |
| -// are forced to manually link against it. It comes in the form of two |
| -// object files that exist in $(VCInstallDir)\crt\src which are memset.obj and |
| -// P4_memset.obj. These two object files rely on the existence of a static |
| -// variable named __sse2_available which indicates the presence of intel sse2 |
| -// extensions. We define it to false which causes a slower but safe code for |
| -// memcpy and memset intrinsics. |
| -// having the linker merge the sections is saving us ~500 bytes. |
| +// have the linker merge the sections, saving us ~500 bytes. |
| #pragma comment(linker, "/MERGE:.rdata=.text") |
| #include <windows.h> |
| @@ -43,9 +36,6 @@ |
| char (&ArraySizeHelper(T (&array)[N]))[N]; |
| #define arraysize(array) (sizeof(ArraySizeHelper(array))) |
| -// Required linker symbol. See remarks above. |
| -extern "C" unsigned int __sse2_available = 0; |
| - |
| namespace mini_installer { |
| typedef StackString<MAX_PATH> PathString; |
| @@ -822,3 +812,36 @@ |
| int result = mini_installer::WMain(::GetModuleHandle(NULL)); |
| ::ExitProcess(result); |
| } |
| + |
| +// VC Express editions don't come with the memset CRT obj file |
| +// and linking to the obj files between versions becomes a bit |
| +// problematic. Therefore, simply implement memset. |
| +// |
| +// This also avoids having to use the __sse2_available hack when |
| +// linking with linking to the dual x64 and x86 obj files. |
|
Mark Mentovai
2011/03/17 20:43:42
Revise “linking with linking to”—pick one. :)
RN
2011/03/18 09:34:24
Yeah.... rewrote that comment and explained it a b
|
| +// extern "C" __sse2_available = |
|
Mark Mentovai
2011/03/17 20:43:42
This comment looks like code but it’s not. defined
RN
2011/03/18 09:34:24
Done.
|
| +// defined(_M_IX86) || defined(_M_AMD64); |
| +extern "C" { |
| + |
| +#pragma function(memset) |
| +void* memset(void* dest, int c, size_t count) { |
| + // Typical 32-bit memset c implementation |
|
Mark Mentovai
2011/03/17 20:43:42
This assumes that dest is properly aligned. It’ll
RN
2011/03/18 09:34:24
Put in more comments about this (even if isn't tha
|
| + size_t adjcount = count>>2; |
|
Mark Mentovai
2011/03/17 20:43:42
Style nit: spaces around operators like >>.
RN
2011/03/18 09:34:24
Done.
|
| + UINT32 fill = (c<<24|c<<16|c<<8|c); |
|
Mark Mentovai
2011/03/17 20:43:42
Here too. (c << 24 | c << 16 | c << 8 | c)
RN
2011/03/18 09:34:24
Done.
|
| + UINT32* dest32 = (unsigned __int32*)dest; |
| + UINT8* dest8 = (unsigned __int8*)dest; |
|
Mark Mentovai
2011/03/17 20:43:42
No need to line up dest8 and dest32, especially wh
RN
2011/03/18 09:34:24
Nice catch, done.
|
| + |
| + // Take care of the ending 0-3 bytes (binary 11 = 3) |
| + switch (count - (adjcount<<2)) { |
|
Mark Mentovai
2011/03/17 20:43:42
Space around that << operator.
RN
2011/03/18 09:34:24
Done.
|
| + case 3: dest8[count - 3] = c; |
|
Mark Mentovai
2011/03/17 20:43:42
The assignments here really belong on the next lin
RN
2011/03/18 09:34:24
OK. Also added a longish comment about how it work
|
| + case 2: dest8[count - 2] = c; |
| + case 1: dest8[count - 1] = c; |
| + } |
| + |
| + while (adjcount-- > 0) |
| + *(dest32++) = fill; |
|
Mark Mentovai
2011/03/17 20:43:42
Fix the indent.
RN
2011/03/18 09:34:24
Assuming the 2 spaces rule, done.
Mark Mentovai
2011/03/18 14:54:47
RN wrote:
|
| + |
| + return dest; |
| +} |
| + |
| +} |
|
Mark Mentovai
2011/03/17 20:43:42
} // extern "C"
RN
2011/03/18 09:34:24
Done.
|