[Ace-users] Re: [tao-users] Access violation if handling a structure containingan octet sequence length > 2604 bytes

Gavin Uttley guttley at iess.co.uk
Wed Aug 22 05:07:21 CDT 2007


Arne,

When I've had problems like this in the past, make sure you include the
sharemem unit as the first include in the project.

HTH
Gav.

-----Original Message-----
From: tao-users-bounces at cse.wustl.edu
[mailto:tao-users-bounces at cse.wustl.edu] On Behalf Of Johnny Willemsen
Sent: 22 August 2007 10:36
To: arne.berger at gmx.de
Cc: tao-users at cse.wustl.edu
Subject: Re: [tao-users] Access violation if handling a structure
containingan octet sequence length > 2604 bytes


Hi,

Please use the mailing lists for communication. In all builds we do have
RTL enabled. Maybe this could be resolved by adding allocation hooks,
see http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2941 for some
details related to that.

Be aware of the fact that we don't maintain and support BCB2006 anymore
because of lack of sponsoring. 

Regards,

Johnny Willemsen
Remedy IT
Postbus 101
2650 AC  Berkel en Rodenrijs
The Netherlands
www.theaceorb.nl / www.remedy.nl  

*** Integrated compile and test statistics see
http://scoreboard.theaceorb.nl ***
*** Commercial service and support for ACE/TAO/CIAO             ***
*** See http://www.theaceorb.nl/en/support.html                 ***

> -----Original Message-----
> From: arne.berger at gmx.de [mailto:arne.berger at gmx.de]
> Sent: Wednesday, August 22, 2007 11:27 AM
> To: Johnny Willemsen
> Subject: Re: Access violation if handling a structure 
> containing an octet sequence length > 2604 bytes
> 
> Hallo Johnny,
> 
> I could not reproduce this affect with a small sample. However with 
> using the codeguard tool I found out that the allocation and 
> deallocation is done from different RTL's. Here are the messages from
> codeguard:
> 
> 
> ------------------------------------------
> Error 00059. 0x340010 (r) (Thread 0x0D8C):
> Resource from different RTL:
> delete[](0x019FC090)
> 
> Call Tree:
>    0x00625D07(=TAO_BD.DLL:0x01:004D07) ..\tao/ 
> Unbounded_Value_Allocation_Traits_T.h#45
>    0x00625CF7(=TAO_BD.DLL:0x01:004CF7) ..\tao/ 
> Unbounded_Octet_Sequence_T.h#250
>    0x00625CDA(=TAO_BD.DLL:0x01:004CDA) ..\tao/ 
> Unbounded_Octet_Sequence_T.h#76
>    0x00683BFA(=TAO_BD.DLL:0x01:062BFA) ..\tao/ 
> Unbounded_Octet_Sequence_T.h#264
>    0x00489961(=PhysicsDataMng.exe:0x01:088961)
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Sequence_CDR_T.h#119
>    0x00489872(=PhysicsDataMng.exe:0x01:088872) sourcescpp
> \sim_common_c.cpp#3397
> 
> The object array (0x019FC090) [size: 2604 bytes] was created with 
> new[] Call Tree:
>    0x004492CC(=PhysicsDataMng.exe:0x01:0482CC) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Value_Allocation_Traits_T.h#40
>    0x00441318(=PhysicsDataMng.exe:0x01:040318) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Octet_Sequence_T.h#247
>    0x004350EC(=PhysicsDataMng.exe:0x01:0340EC) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Octet_Sequence_T.h#57
>    0x004898E2(=PhysicsDataMng.exe:0x01:0888E2) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Sequence_CDR_T.h#111
>    0x00489872(=PhysicsDataMng.exe:0x01:088872) sourcescpp
> \sim_common_c.cpp#3397
>    0x00489AAF(=PhysicsDataMng.exe:0x01:088AAF) sourcescpp
> \sim_common_c.cpp#3425
> 
> ------------------------------------------
> Error 00058. 0x340010 (r) (Thread 0x0D8C):
> Resource from different RTL:
> delete[](0x01A0CAD0)
> 
> Call Tree:
>    0x00625D07(=TAO_BD.DLL:0x01:004D07) ..\tao/ 
> Unbounded_Value_Allocation_Traits_T.h#45
>    0x00625CF7(=TAO_BD.DLL:0x01:004CF7) ..\tao/ 
> Unbounded_Octet_Sequence_T.h#250
>    0x00625CDA(=TAO_BD.DLL:0x01:004CDA) ..\tao/ 
> Unbounded_Octet_Sequence_T.h#76
>    0x00683BFA(=TAO_BD.DLL:0x01:062BFA) ..\tao/ 
> Unbounded_Octet_Sequence_T.h#264
>    0x00489961(=PhysicsDataMng.exe:0x01:088961)
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Sequence_CDR_T.h#119
>    0x00489872(=PhysicsDataMng.exe:0x01:088872) sourcescpp
> \sim_common_c.cpp#3397
> 
> The object array (0x01A0CAD0) [size: 2606 bytes] was created with 
> new[] Call Tree:
>    0x004492CC(=PhysicsDataMng.exe:0x01:0482CC) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Value_Allocation_Traits_T.h#40
>    0x00441318(=PhysicsDataMng.exe:0x01:040318) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Octet_Sequence_T.h#247
>    0x004350EC(=PhysicsDataMng.exe:0x01:0340EC) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Octet_Sequence_T.h#57
>    0x004898E2(=PhysicsDataMng.exe:0x01:0888E2) 
> D:\Programme\Borland\BDS
> \4.0\ACETAO\\include\tao/Unbounded_Sequence_CDR_T.h#111
>    0x00489872(=PhysicsDataMng.exe:0x01:088872) sourcescpp
> \sim_common_c.cpp#3397
>    0x00489AAF(=PhysicsDataMng.exe:0x01:088AAF) sourcescpp
> \sim_common_c.cpp#3425
> 
> 
> Codeguard avoids the access violation. Without linking the codeguard 
> library the server program crashes if more than 2604 bytes was 
> received.
> 
> In my large project I firstly build a static library from all IDL 
> generated cpp files. This library is linked to the server process 
> without using the option "Use dynamic RTL". If I build all (the 
> library and the server.exe) with this option no errors occur. If I 
> directly add the IDL generated CPP files to the server project file 
> without using the library it works fine too. Also the error from 
> codeguard tool is lost.
> 
> It seems to me a version without using dynamic RTL is not possible 
> with usage of BDS2006 ?? Now I had to change all projects and to set 
> the option "Use dynamic RTL" to be sure the TAO unbounded sequences 
> are working correctly. Or do you have a different idea?
> 
> Thanks for help
> 
> Best regards
> Arne Berger
> 
> On Aug 17, 12:02 pm, "Johnny Willemsen" <jwillem... at remedy.nl> wrote:
> > Hi,
> >
> > I am not familiar with any limitation, please make a small
> reproducer as
> > test program and also try x.5.10.
> >
> > Be aware of the fact that BCB2006 isn't maintained anymore
> as supported
> > platform.
> >
> > Regards,
> >
> > Johnny Willemsen
> > Remedy IT
> > Postbus 101
> > 2650 AC  Berkel en Rodenrijs
> > The Netherlandswww.theaceorb.nl/www.remedy.nl
> >
> > *** Integrated compile and test statistics
> seehttp://scoreboard.theaceorb.nl***
> > *** Commercial service and support for ACE/TAO/CIAO             ***
> > *** Seehttp://www.theaceorb.nl/en/support.html                ***
> >
> > <arne.ber... at gmx.de> wrote in message
> >
> > <news:1187340823.006680.10270 at 19g2000hsx.googlegroups.com>...
> > Hi
> >
> > I have a problem if receiving an unbounded octet sequence
> by my server
> > implementation. Following I'm using the PRF form:
> >
> >     ACE VERSION:
> >         5.5.4
> >
> >     HOST MACHINE and OPERATING SYSTEM:
> >         Intel(R) Core(TM)2 and Windows XP Prof. V2002 SP2
> >
> >     COMPILER NAME AND VERSION (AND PATCHLEVEL):
> >         Borland Developer Studio for MicrosoftR WindowsT Version 
> > 10.0.2288.42451 Update 2
> >
> >     THE $ACE_ROOT/ace/config.h FILE
> >         config-win32.h
> >
> >     AREA/CLASS/EXAMPLE AFFECTED:
> >         TAO::template <typename stream>
> >         bool demarshal_sequence(stream & strm, 
> > TAO::unbounded_value_sequence <CORBA::Short> & target)
> >         and
> >         TAO::details::template<typename T, bool dummy>
> >         struct unbounded_value_allocation_traits::freebuf(value_type
> > *)
> >
> >     DOES THE PROBLEM AFFECT:
> >         COMPILATION: no
> >         LINKING: no
> >         EXECUTION: yes
> >         OTHER: no
> >
> >     SYNOPSIS:
> >         Access violation if handling a structure containing an octet

> > sequence length > 2604 bytes
> >
> >     DESCRIPTION:
> >         I've implemented a server interface contains a method with a
> >         structured "in" parameter. The structure consists of several

> > sequences
> >         (key-value-pairs like string-long, string-double, string- 
> > binary data and so on).
> >         The entries of the binary data sequences is defined as
> >             struct SimBinary
> >             {
> >               string          key;     // identifier
> >               sequence<octet> value;   // the binary data
> >             };
> >             typedef sequence<SimBinary> SimBinarySeq;
> >         If any of these octet sequences contains more than
> 2604 bytes
> > an
> >         access violation occurs in
> >             TAO::details::template<typename T, bool dummy>
> >             struct 
> > unbounded_value_allocation_traits::freebuf(value_type *buffer)
> >             {
> >               delete [] buffer;  // access violation
> >             }
> >         Within template
> >             TAO::template <typename stream>
> >             bool demarshal_sequence(stream & strm, 
> > TAO::unbounded_value_sequence <CORBA::Short> & target)
> >             {
> >               ...
> >              sequence tmp(new_length);
> >               ...
> >             }
> >         a temporary instance "tmp" is created. At the end
> of function
> > block the destructor
> >             ~unbounded_value_sequence<CORBA::Octet>();
> >         is called and invokes
> >             freebuf(buffer);
> >
> >         Until length of 2604 bytes no problems occur. Is
> there a limit
> > I've to look after?
> >         Nevertheless an access violation should not occur!
> >
> >     REPEAT BY:
> >         See description. After first exception thread is died.
> >
> >     SAMPLE FIX/WORKAROUND:
> >         I will produce an example if necessary. A workaround is not 
> > possible.
> >
> > Thanks if anyone can promp help me.
> >
> > Best regards
> > Arne Berger
> >
> > ----------
> 
> 

_______________________________________________
tao-users mailing list
tao-users at mail.cse.wustl.edu
http://mail.cse.wustl.edu/mailman/listinfo/tao-users

_____________________________________________________________________
This message has been checked for all known viruses by the 
MessageLabs Virus Scanning Service.



This message has been sent from Chubb Electronic Security Systems Ltd.

Chubb Electronic Security Systems Ltd.
Shadsworth Road
Blackburn
BB1 2PR
United Kingdom
Tel +44(0) 1254 688688
a UTC Group Company

This e-mail message and any attachments are confidential
and are intended for the use of the addressee only. If you 
are not the addressee you should not copy or use them for 
any purpose, nor disclose their contents to anyone else. 
If you believe you have received this e-mail by mistake please 
notify us immediately by telephoning +44 (0) 1254 688688.
_____________________________________________________________________
This message has been checked for all known viruses by the MessageLabs Virus Scanning Service.



More information about the Ace-users mailing list