[fpc-pascal] Reproducible code: DLL calling Firebird crashes
Mark Morgan Lloyd
markMLl.fpc-pascal at telemetry.co.uk
Tue Sep 30 15:06:04 CEST 2014
Michael Van Canneyt wrote:
>>>> However I'd precede that by a thought based on what Jose said. In
>>>> your example, you're opening the database in the initialisation
>>>> block of businesslayer.pas, which is invoked at an arbitrary
>>>> position in the init sequence of the DLL/so. If that operation were
>>>> moved instead to the initialisation block of testdbdll.lpr, which in
>>>> the context of the DLL/so is analogous to a program's main block, it
>>>> might work.
>>>
>>> No. this is not correct. For a library, this is analogous to
>>> initialization code of a unit, it's just the 'last' unit being
>>> initialized.
>>
>> Does the main program explicitly call the initialisation entry point
>> of the (dynamically-loaded) library, or it this done by the OS? I was
>> under the impression that the two were basically asynchronous and (as
>> a particular example) both the program and the library would have
>> distinct copies of the system unit with their own global variables
>> etc. hence the memory manager problem.
>
> The memory manager problem is completely unrelated to this. DLL and
> calling program simply have different copies of the FPC memory manager.
> That is what needs to be solved with dynamic packages.
Yes, agreed. Except that if cmem (or whatever) isn't being used there
are two completely separate copies of the memory manager because...
> As far as I know, the initialization entry point is called automatically.
> But the compiler experts should confirm this. IIRC the behaviour changed
> as the support for libraries improved;
..(pending comment from compiler experts) there are completely separate
trees of units in the main program and each dynamically-loaded library.
The OS calls the initialisation block(s) for each library, and then
finally calls the initialisation block for the main program. So in the
context of one particular library, code in the main library
initialisation block should have a similar standing to that in the main
program initialisation block: everything else in that context (i.e. in
the library or in the main program) has been initialised before it is
called, and when it exits it goes back to the OS (possibly via
finalisation blocks).
--
Mark Morgan Lloyd
markMLl .AT. telemetry.co .DOT. uk
[Opinions above are the author's, not those of his employers or colleagues]
More information about the fpc-pascal
mailing list