PInvoke & LoadLibrary fail - DLL exists

  • Thread starter Thread starter xtravar
  • Start date Start date
X

xtravar

p/Invoke says "Can't find x.dll" when the function's called.

I tried using LoadLibrary on the DLL and it fails 99.9% of the time.

I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small random
failure rate. There's no consistency between the OS and CPU of the
failures.

I tried getting the last win32 error and it was 120, which is of no
use.

Any ideas? This is rather urgent.
 
What sorts of devices are we talking about? These are Windows Mobile? Your
own, with various builds of various operating systems, etc.?

I'm not so sure that 120 is of no use. It indicates that something that's
being done is not possible with the set of operating system components built
into the device. If we're talking Windows Mobile, it might indicate that,
in your DllMain(), you're doing something that can't be done, returning an
error, and therefore not allowing yourself to be loaded. If it's a custom
Windows CE device, it might indicate that the file was found, but it's
compressed in ROM and the compression component isn't there (that's just an
example of the sort of thing it could be; I don't think it's possible to
build the OS in that way).

Every problem is critical to the guy asking!

Paul T.
 
Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device

So, I don't think the device type is really making a difference
here...

There's no dllmain that we explicitly coded. The compiler may have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.

Does that help diagnose? Thanks!
 
Linked with what? Dump the DLL dependencies using dumpbin or the dependency
viewer from Visual Studio. What else is running? If you do a soft reset
and run your code immediately, does it ever happen?

Paul T.
 
Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.

The linker command line only shows these libs, which, as far as I can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib commctrl.lib.

They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.

This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.

Thanks!
 
If you actively import only coredll, you don't need ole32, oleaut32, uuid,
or commctrl. How is the DLL getting to the device? You're installing it
with an installer? You're copying it from a storage card? You're deploying
it with <what> IDE? The DLL is retargeted for each of the indicated
platform versions? That is, you're recompiling against PPC2003 when you run
it on the HP PPC2003 device? Then target Windows Mobile 5 SDK when running
the result on WM5?

Paul T.

Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.

The linker command line only shows these libs, which, as far as I can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib commctrl.lib.

They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.

This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.

Thanks!

Linked with what? Dump the DLL dependencies using dumpbin or the
dependency
viewer from Visual Studio. What else is running? If you do a soft reset
and run your code immediately, does it ever happen?

Paul T.


Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device
So, I don't think the device type is really making a difference
here...
There's no dllmain that we explicitly coded. The compiler may have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.
Does that help diagnose? Thanks!
On Feb 15, 3:43 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
What sorts of devices are we talking about? These are Windows Mobile?
Your
own, with various builds of various operating systems, etc.?
I'm not so sure that 120 is of no use. It indicates that something
that's
being done is not possible with the set of operating system components
built
into the device. If we're talking Windows Mobile, it might indicate
that,
in your DllMain(), you're doing something that can't be done,
returning
an
error, and therefore not allowing yourself to be loaded. If it's a
custom
Windows CE device, it might indicate that the file was found, but it's
compressed in ROM and the compression component isn't there (that's
just
an
example of the sort of thing it could be; I don't think it's possible
to
build the OS in that way).
Every problem is critical to the guy asking!
p/Invoke says "Can't find x.dll" when the function's called.
I tried using LoadLibrary on the DLL and it fails 99.9% of the time.
I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small random
failure rate. There's no consistency between the OS and CPU of the
failures.
I tried getting the last win32 error and it was 120, which is of no
use.
Any ideas? This is rather urgent.
 
I'm not actively importing anything - if you can tell me where to drop
those things from the linker, I'd do so in a heartbeat.

The DLL is compiled for PPC2003, but apparently it has about the same
success rate on WM5 devices.

If you actively import only coredll, you don't need ole32, oleaut32, uuid,
or commctrl. How is the DLL getting to the device? You're installing it
with an installer? You're copying it from a storage card? You're deploying
it with <what> IDE? The DLL is retargeted for each of the indicated
platform versions? That is, you're recompiling against PPC2003 when you run
it on the HP PPC2003 device? Then target Windows Mobile 5 SDK when running
the result on WM5?

Paul T.


Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.
The linker command line only shows these libs, which, as far as I can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib commctrl.lib.
They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.
This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.
Linked with what? Dump the DLL dependencies using dumpbin or the
dependency
viewer from Visual Studio. What else is running? If you do a soft reset
and run your code immediately, does it ever happen?
Paul T.

Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device
So, I don't think the device type is really making a difference
here...
There's no dllmain that we explicitly coded. The compiler may have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.
Does that help diagnose? Thanks!
On Feb 15, 3:43 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
What sorts of devices are we talking about? These are Windows Mobile?
Your
own, with various builds of various operating systems, etc.?
I'm not so sure that 120 is of no use. It indicates that something
that's
being done is not possible with the set of operating system components
built
into the device. If we're talking Windows Mobile, it might indicate
that,
in your DllMain(), you're doing something that can't be done,
returning
an
error, and therefore not allowing yourself to be loaded. If it's a
custom
Windows CE device, it might indicate that the file was found, but it's
compressed in ROM and the compression component isn't there (that's
just
an
example of the sort of thing it could be; I don't think it's possible
to
build the OS in that way).
Every problem is critical to the guy asking!
Paul T.

p/Invoke says "Can't find x.dll" when the function's called.
I tried using LoadLibrary on the DLL and it fails 99.9% of the time.
I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small random
failure rate. There's no consistency between the OS and CPU of the
failures.
I tried getting the last win32 error and it was 120, which is of no
use.
Any ideas? This is rather urgent.
 
Linking with an import library is actively importing it, in my imprecise
terminology, so you are actively importing coredll.dll (if it's not there,
your code will not load). The same should not be true of the ole32 stuff,
according to your last message, where you say nothing about needing COM. If
that's the case, removing those import libraries is a good thing.

You had to set them in the link settings to get them there; they are not set
by default. Where, exactly you find them depends on which IDE you are
using...

Paul T.

I'm not actively importing anything - if you can tell me where to drop
those things from the linker, I'd do so in a heartbeat.

The DLL is compiled for PPC2003, but apparently it has about the same
success rate on WM5 devices.

If you actively import only coredll, you don't need ole32, oleaut32,
uuid,
or commctrl. How is the DLL getting to the device? You're installing it
with an installer? You're copying it from a storage card? You're
deploying
it with <what> IDE? The DLL is retargeted for each of the indicated
platform versions? That is, you're recompiling against PPC2003 when you
run
it on the HP PPC2003 device? Then target Windows Mobile 5 SDK when
running
the result on WM5?

Paul T.


Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.
The linker command line only shows these libs, which, as far as I can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib commctrl.lib.
They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.
This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.

On Feb 18, 3:57 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
Linked with what? Dump the DLL dependencies using dumpbin or the
dependency
viewer from Visual Studio. What else is running? If you do a soft
reset
and run your code immediately, does it ever happen?
Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device
So, I don't think the device type is really making a difference
here...
There's no dllmain that we explicitly coded. The compiler may have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.
Does that help diagnose? Thanks!
On Feb 15, 3:43 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
What sorts of devices are we talking about? These are Windows
Mobile?
Your
own, with various builds of various operating systems, etc.?
I'm not so sure that 120 is of no use. It indicates that something
that's
being done is not possible with the set of operating system
components
built
into the device. If we're talking Windows Mobile, it might
indicate
that,
in your DllMain(), you're doing something that can't be done,
returning
an
error, and therefore not allowing yourself to be loaded. If it's a
custom
Windows CE device, it might indicate that the file was found, but
it's
compressed in ROM and the compression component isn't there (that's
just
an
example of the sort of thing it could be; I don't think it's
possible
to
build the OS in that way).
Every problem is critical to the guy asking!
p/Invoke says "Can't find x.dll" when the function's called.
I tried using LoadLibrary on the DLL and it fails 99.9% of the
time.
I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small
random
failure rate. There's no consistency between the OS and CPU of
the
failures.
I tried getting the last win32 error and it was 120, which is of
no
use.
Any ideas? This is rather urgent.
 
Those libs aren't anywhere within my project file - I tried searching
the text of it, so those libs are being linked due to Visual Studio
inherent functionality. However, I don't think that's related to my
problem since it's not causing any imports from those DLLs - right?

Linking with an import library is actively importing it, in my imprecise
terminology, so you are actively importing coredll.dll (if it's not there,
your code will not load). The same should not be true of the ole32 stuff,
according to your last message, where you say nothing about needing COM. If
that's the case, removing those import libraries is a good thing.

You had to set them in the link settings to get them there; they are not set
by default. Where, exactly you find them depends on which IDE you are
using...

Paul T.


I'm not actively importing anything - if you can tell me where to drop
those things from the linker, I'd do so in a heartbeat.
The DLL is compiled for PPC2003, but apparently it has about the same
success rate on WM5 devices.
If you actively import only coredll, you don't need ole32, oleaut32,
uuid,
or commctrl. How is the DLL getting to the device? You're installing it
with an installer? You're copying it from a storage card? You're
deploying
it with <what> IDE? The DLL is retargeted for each of the indicated
platform versions? That is, you're recompiling against PPC2003 when you
run
it on the HP PPC2003 device? Then target Windows Mobile 5 SDK when
running
the result on WM5?
Paul T.

Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.
The linker command line only shows these libs, which, as far as I can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib commctrl.lib.
They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.
This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.
Thanks!
On Feb 18, 3:57 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
Linked with what? Dump the DLL dependencies using dumpbin or the
dependency
viewer from Visual Studio. What else is running? If you do a soft
reset
and run your code immediately, does it ever happen?
Paul T.

Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device
So, I don't think the device type is really making a difference
here...
There's no dllmain that we explicitly coded. The compiler may have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.
Does that help diagnose? Thanks!
On Feb 15, 3:43 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
What sorts of devices are we talking about? These are Windows
Mobile?
Your
own, with various builds of various operating systems, etc.?
I'm not so sure that 120 is of no use. It indicates that something
that's
being done is not possible with the set of operating system
components
built
into the device. If we're talking Windows Mobile, it might
indicate
that,
in your DllMain(), you're doing something that can't be done,
returning
an
error, and therefore not allowing yourself to be loaded. If it's a
custom
Windows CE device, it might indicate that the file was found, but
it's
compressed in ROM and the compression component isn't there (that's
just
an
example of the sort of thing it could be; I don't think it's
possible
to
build the OS in that way).
Every problem is critical to the guy asking!
Paul T.

p/Invoke says "Can't find x.dll" when the function's called.
I tried using LoadLibrary on the DLL and it fails 99.9% of the
time.
I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small
random
failure rate. There's no consistency between the OS and CPU of
the
failures.
I tried getting the last win32 error and it was 120, which is of
no
use.
Any ideas? This is rather urgent.
 
Your IDE is trying to link with them, which seems wrong to me. It should
not know anything about those libraries unless you tell it, I think. The
EXE definitely shows to dumpbin or the dependency viewer as a Windows CE
executable, right? A desktop executable would normally give a different
error return from trying to load it under CE (it just won't work), but I
can't figure out where those libraries are getting into the mix and it makes
me nervous. Nothing else jumps out at me as the problem and I've *never*
had a situation where a DLL sometimes loads and sometimes not unless it was
my fault in a fairly obvious way.

You could start over and rebuild an empty Smart Device Application project
targeting the right SDK and then add your source files to it. I'm low on
ideas...

Paul T.

Those libs aren't anywhere within my project file - I tried searching
the text of it, so those libs are being linked due to Visual Studio
inherent functionality. However, I don't think that's related to my
problem since it's not causing any imports from those DLLs - right?

Linking with an import library is actively importing it, in my imprecise
terminology, so you are actively importing coredll.dll (if it's not
there,
your code will not load). The same should not be true of the ole32
stuff,
according to your last message, where you say nothing about needing COM.
If
that's the case, removing those import libraries is a good thing.

You had to set them in the link settings to get them there; they are not
set
by default. Where, exactly you find them depends on which IDE you are
using...

Paul T.


I'm not actively importing anything - if you can tell me where to drop
those things from the linker, I'd do so in a heartbeat.
The DLL is compiled for PPC2003, but apparently it has about the same
success rate on WM5 devices.
On Feb 18, 4:59 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
If you actively import only coredll, you don't need ole32, oleaut32,
uuid,
or commctrl. How is the DLL getting to the device? You're installing
it
with an installer? You're copying it from a storage card? You're
deploying
it with <what> IDE? The DLL is retargeted for each of the indicated
platform versions? That is, you're recompiling against PPC2003 when
you
run
it on the HP PPC2003 device? Then target Windows Mobile 5 SDK when
running
the result on WM5?
Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.
The linker command line only shows these libs, which, as far as I
can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib
commctrl.lib.
They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.
This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.

On Feb 18, 3:57 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
Linked with what? Dump the DLL dependencies using dumpbin or the
dependency
viewer from Visual Studio. What else is running? If you do a soft
reset
and run your code immediately, does it ever happen?
Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device
So, I don't think the device type is really making a difference
here...
There's no dllmain that we explicitly coded. The compiler may
have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.
Does that help diagnose? Thanks!
On Feb 15, 3:43 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam
AT
no instrument no spam DOT com> wrote:
What sorts of devices are we talking about? These are Windows
Mobile?
Your
own, with various builds of various operating systems, etc.?
I'm not so sure that 120 is of no use. It indicates that
something
that's
being done is not possible with the set of operating system
components
built
into the device. If we're talking Windows Mobile, it might
indicate
that,
in your DllMain(), you're doing something that can't be done,
returning
an
error, and therefore not allowing yourself to be loaded. If
it's a
custom
Windows CE device, it might indicate that the file was found,
but
it's
compressed in ROM and the compression component isn't there
(that's
just
an
example of the sort of thing it could be; I don't think it's
possible
to
build the OS in that way).
Every problem is critical to the guy asking!
p/Invoke says "Can't find x.dll" when the function's called.
I tried using LoadLibrary on the DLL and it fails 99.9% of the
time.
I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small
random
failure rate. There's no consistency between the OS and CPU
of
the
failures.
I tried getting the last win32 error and it was 120, which is
of
no
use.
Any ideas? This is rather urgent.
 
Dumpbin also shows that none of the DLLs that those libs would pull in
are being pulled in, so the linker's pretty much ignoring those libs
since I'm not calling any of their code. Visual Studio 2005
apparently passes them to the linker by default, for some reason.

I found out why the DLLs wouldn't load, but I don't understand it. If
I LoadLibrary when my application starts, it succeeds, meaning that
this must be memory related. However, I am nowhere near my memory
limit when LoadLibrary fails later in the app.

Obviously, because I call LoadLibrary when the app starts, p/invokes
now work. This isn't really an ideal solution, though, and I am
curious as to what makes the difference.

Your IDE is trying to link with them, which seems wrong to me. It should
not know anything about those libraries unless you tell it, I think. The
EXE definitely shows to dumpbin or the dependency viewer as a Windows CE
executable, right? A desktop executable would normally give a different
error return from trying to load it under CE (it just won't work), but I
can't figure out where those libraries are getting into the mix and it makes
me nervous. Nothing else jumps out at me as the problem and I've *never*
had a situation where a DLL sometimes loads and sometimes not unless it was
my fault in a fairly obvious way.

You could start over and rebuild an empty Smart Device Application project
targeting the right SDK and then add your source files to it. I'm low on
ideas...

Paul T.


Those libs aren't anywhere within my project file - I tried searching
the text of it, so those libs are being linked due to Visual Studio
inherent functionality. However, I don't think that's related to my
problem since it's not causing any imports from those DLLs - right?
Linking with an import library is actively importing it, in my imprecise
terminology, so you are actively importing coredll.dll (if it's not
there,
your code will not load). The same should not be true of the ole32
stuff,
according to your last message, where you say nothing about needing COM.
If
that's the case, removing those import libraries is a good thing.
You had to set them in the link settings to get them there; they are not
set
by default. Where, exactly you find them depends on which IDE you are
using...
Paul T.

I'm not actively importing anything - if you can tell me where to drop
those things from the linker, I'd do so in a heartbeat.
The DLL is compiled for PPC2003, but apparently it has about the same
success rate on WM5 devices.
On Feb 18, 4:59 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
If you actively import only coredll, you don't need ole32, oleaut32,
uuid,
or commctrl. How is the DLL getting to the device? You're installing
it
with an installer? You're copying it from a storage card? You're
deploying
it with <what> IDE? The DLL is retargeted for each of the indicated
platform versions? That is, you're recompiling against PPC2003 when
you
run
it on the HP PPC2003 device? Then target Windows Mobile 5 SDK when
running
the result on WM5?
Paul T.

Both of the DLLs I am trying to load only show coredll.dll as a
dependency using dumpbin.
The linker command line only shows these libs, which, as far as I
can
tell, are standard. The DLLs only use libc functions.
coredll.lib corelibc.lib ole32.lib oleaut32.lib uuid.lib
commctrl.lib.
They're both compiled as ARMV4 (not ARMV4I) so CPU type does not
matter.
This happens immediately after a soft reset, and with few other
processes running, so it does not seem to be related to another
running process.
Thanks!
On Feb 18, 3:57 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam AT
no instrument no spam DOT com> wrote:
Linked with what? Dump the DLL dependencies using dumpbin or the
dependency
viewer from Visual Studio. What else is running? If you do a soft
reset
and run your code immediately, does it ever happen?
Paul T.

Most problems: HP VGA PPC 2003 device
Fewer problems: HP QVGA WM5 device
Same: Handheld Products QVGA WM5 device
No problems: Dell Axim VGA WM5 device
So, I don't think the device type is really making a difference
here...
There's no dllmain that we explicitly coded. The compiler may
have
put something in, I guess. The DLLs aren't dependent on anything
exotic, either - they're fairly self-contained.
Does that help diagnose? Thanks!
On Feb 15, 3:43 pm, "Paul G. Tobey [eMVP]" <p space tobey no spam
AT
no instrument no spam DOT com> wrote:
What sorts of devices are we talking about? These are Windows
Mobile?
Your
own, with various builds of various operating systems, etc.?
I'm not so sure that 120 is of no use. It indicates that
something
that's
being done is not possible with the set of operating system
components
built
into the device. If we're talking Windows Mobile, it might
indicate
that,
in your DllMain(), you're doing something that can't be done,
returning
an
error, and therefore not allowing yourself to be loaded. If
it's a
custom
Windows CE device, it might indicate that the file was found,
but
it's
compressed in ROM and the compression component isn't there
(that's
just
an
example of the sort of thing it could be; I don't think it's
possible
to
build the OS in that way).
Every problem is critical to the guy asking!
Paul T.

p/Invoke says "Can't find x.dll" when the function's called.
I tried using LoadLibrary on the DLL and it fails 99.9% of the
time.
I have seen rare cases when it loads.
It loads on other devices perfectly. Others, it has a small
random
failure rate. There's no consistency between the OS and CPU
of
the
failures.
I tried getting the last win32 error and it was 120, which is
of
no
use.
Any ideas? This is rather urgent.
 
Hi,

I found out why the DLLs wouldn't load, but I don't understand it. If
I LoadLibrary when my application starts, it succeeds, meaning that
this must be memory related. However, I am nowhere near my memory
limit when LoadLibrary fails later in the app.

Obviously, because I call LoadLibrary when the app starts, p/invokes
now work. This isn't really an ideal solution, though, and I am
curious as to what makes the difference.

This might be a case of a well documented issue called "DLL Crunch" as
documented on MSDN in the following article "Windows CE .NET Advanced Memory
Management" available at
http://msdn2.microsoft.com/en-us/library/ms836325.aspx (see the section at
the bottom labeled "DLL Load Problem").

Although various improvements have occurred since Pocket PC 2002 (when the
article was originally written) it's possible applications that constantly
load/unload DLLs and/or reference lots of small DLLs still fall into
similiar situations.

This would explain why if you call LoadLibrary early on in the life time of
your application you ensure the PInvoke calls succeed, because when the
PInvoke layer indirectly calls LoadLibrary it will notice the DLL is already
loaded by the process and utilise it.

Hope this helps,
Christopher Fairbairn
 
Could you then explain why I can load all the DLLs I need to
afterward?
Are .Net assemblies treated differently than native DLLs?
 
Absolutely they are. Managed DLLs are loaded as memory-mapped files and
really take up no virtual space. A native DLL requires a contiguous 64k
minimum and often takes it from all processes, not just the current process
(again, see Boling's article that Christopher pointed to).

There's a reasonably good webcast on MSDN that covers memory management in
the compact framework that discusses how assemblies and classes are loaded.


--

Chris Tacke, Embedded MVP
OpenNETCF Consulting
Giving back to the embedded community
http://community.OpenNETCF.com
 
Back
Top