InterSystems Documentation 
Caché and Ensemble Maintenance Kit Release Notes Archive


Welcome and thank you for using InterSystems products.
The current maintenance kits are Caché and Ensemble 2010.2.3. This document is only part of the available maintenance kit documentation. The full set of documents is available in the docs subdirectory of the product installation directory. Release notes and related material are available as follows:

This document is a historical archive of changes since the original 2010.2 release, but prior to the current maintenance kit. Changes unique to the current maintenance kit are described in relnotes.htm.
This document includes the following sections:

General Announcements
InterSystems advises all users to recompile their application classes as part of the upgrade process so as to take advantage of all the performance improvements as well as other changes that may affect them in this release.
Anyone upgrading from a Caché release at or before 5.0 will need a new license key.

InterSystems News, Alerts and Advisories
From time to time, InterSystems publishes items of immediate importance to users of our software. These include alerts, mission critical issues, important updates, fixes, and release announcements.

The most current list can be obtained from the InterSystems Web site.

Users should check this list periodically to obtain the latest information on issues that may have an effect on the operation of their site.


Online Documentation
As a convenience to our users, InterSystems provides online access to documentation for recent product versions at the InterSystems documentation Web site.

Change Reports for Previous Maintenance Kits
The following are the previous maintenance releases of Caché 2010.2:


Change Reports for 2010.2.2

Category: CSP.Gateway
Platforms: HP-UX
DevKey: CMT886
Summary: Restructure the main control block in the shared memory sector to avoid a BUS error on 64-bit HPUX systems

Description:

This change modifies the control block to align data items so that references to them do not cause bus errors on 64-bit systems.

Category: Ensemble
Platforms: All
DevKey: MC1161
Summary: Fix bug where alarm requests are lost during production suspension

Description:

This corrects a serious situation that occurs during shutdown. At this time, all outstanding alarm requests are lost. On subsequent startup and resumption of the production, the processes that are waiting on their alarm requests will not receive them.

The change is to save the alarms, preserving them across the shutdown/startup and make them available to the applications when they resume operation.


Category: Ensemble
Platforms: All
DevKey: TAP1076
Summary: Write only complete LOB chunks to stream global from SQL Adapter

Description:

This change causes the class EnsLib.SQL.GatewayResultSet used by the SQL Adapters to write only complete LOB chunks to the underlying stream global rather than storing each sub-chunk as it arrives over the xDBC channel. This prevents journaling of the partially completed chunk multiple times which reduces the total amount of journaled data to the minimum necessary.

Category: Ensemble
Platforms: All
DevKey: TAP1097
Summary: Increase top 1m to top 100m in Purge query

Description:

This change increases the TOP clause in the SQL used to purge messages from 1,000,000 to 100,000,000.

Category: Ensemble
Platforms: All
DevKey: TAP1100
Summary: Make SQL Adapters recognize JDBC network disconnect when prepareStatement() fails with no additional error info

Description:

When the JDBC Gateway's JVM is restarted while a Production is running and SQL Adapter activity is in progress, it can happen that the Adapter has an open connection instance that is no longer viable. In this case, when the Adapter attempts to prepare a statement, the prepareStatement() command to the JVM will fail. The adapter needs to interpret this as a disconnect event so that it will jettison its connection instance and establish a new one.

This change makes the Adapter detect the failure and interpret it as a disconnect event.


Category: Ensemble.Adapter
Platforms: All
DevKey: DMC802
Summary: Ensemble/ebXML: Support versioning of CPA instances

Description:

This changes adds support for versioning of CPA instances. CPA instances are now stored using an IDKEY of the CPAId and the Version property. A new instance method BumpVersion() will find the next highest Version number for the specified CPAId. CPA instances can also be "disabled" by setting the new Status property to disabled. A new helper method has been added:
    CPAForCPAId(<cpaid>)
This will locate the CPA instance by CPAId and find the highest version that is marked as active.

Category: Ensemble.Adapter
Platforms: All
DevKey: DMC804
Summary: Ensemble/ebXML: Support custom XML in ebXML manifest

Description:

Some external situations require that additional XML tags be present in the ebXML Manifest, in this specific case, it is a Payload tag. The existing implementation allowed for this, but would capture the XML as a string in an "any" property. However, this turns out to be useless because the original namespace information was included in the SOAP envelope and unavailable to the user.

This change captures the Payload tag properly.


Category: Ensemble.Adapter
Platforms: All
DevKey: DMC805
Summary: Ensemble/ebXML: CPA TimeToLive should be a string not an integer

Description:

This change modifies the TimeToLive property of the CPA so it is treated as a string, in an XSD duration format.

Category: Ensemble.Adapter
Platforms: All
DevKey: DMC806
Summary: Ensemble/ebXML: Only call SendDeferredResponse() if response has been pre-fetched

Description:

Not all users will track messages or associate a deferred response with a message in the message tracker. In this case, where tracking is needed, but responses are not pre-fetched, this modification ensures that Ensemble does not call SendDeferredResponse() unnecessarily.

Category: Ensemble.Adapter
Platforms: All
DevKey: JN928
Summary: Handle Empty Transfer Syntax In DICOM Association Negotiation

Description:
Some DICOM client software sends empty instances of DICOM transfer syntax specification in the association negotiation phase. While this is confusing, it is not specifically prohibited in the standard. This correction changes the TCP adapter to just ignore the irrelevant data.

Category: Ensemble.DTL
Platforms: All
DevKey: DMC803
Summary: Ensemble/ebXML: Add VDoc/DTL support for TimeCreated property

Description:

The "time created" timestamp was needed for auditing purposes, which was in fact present in the implementation, but wasn't visible to DTL. This change makes it visible.

Category: Languages.COS
Platforms: All
DevKey: GGC455
Summary: Correct ptrie arrays under boundary conditions

Description:

This corrects a situation where $ORDER or $QUERY would return incorrect results under certain boundary conditions, for example, finding the first item in a newly created local array.

Category: Networking.ECP
Platforms: All
DevKey: GK883
Summary: Unexpected routine or class load error across ECP

Description:

This correction fixes an error where a class load or save across ECP may raise an unexpected error (<ROUTINELOAD> or <STORE>), when the routine object global cache is empty and the load/save references a routine > 32656 chars.

Category: Object
Platforms: All
DevKey: MC1159
Summary: Redefine /checkuptodate qualifier in Export group to make it compatible

Description:

This change redefines /checkuptodate qualifier in Export group to make it compatible with that of the Compiler group, but still accepts the older values of 0 and 1.

Category: Object.LanguageBindings.LCB
Platforms: All
DevKey: JMM414
Summary: LCB correctly read %Time fields that were stored via SQL

Description:

This change fixes two problems with the the projection class for the Cache %Time datatype in the C++ binding and Light C++ Binding.

The first problem was that d_time::operator!=(const d_time&) always returned true. The second problem (in Light C++ Binding only) was that it stored d_time in a different format ("hh:mm:ss") from the format used by SQL and other object APIs (which store time as a string representation of the number of seconds elapsed since midnite).

Thus, times stored by LCB could not be correctly read by SQL, and vice-versa. With this change, times are stored in the same format used by SQL, and can correctly read times that were stored in either format.


Category: Object.LanguageBindings.MDS
Platforms: All
DevKey: JMM411
Summary: MDS correctly ignore interface field for which no actual type is provided

Description:
This change causes MDS to correctly ignore object fields which are defined as interfaces, and do not have any actual type specified. Prior to this change, MDS got an access violation within MDSNodeReference.setTypeInfo if called for a class containing such a field.

Category: Object.Gateway
Platforms: All
DevKey: TAP1114
Summary: Force %Net.Gateway Closed flag =1 if error connecting or disconnecting

Description:

The Remote Gateway has a Closed flag that indicates whether its TCP connection to the JVM is open or not. This change ensures that, in disconnecting or failing to connect the Gateway when the connection is unexpectedly lost, the Closed flag is correctly updated.

Category: Object.Library
Platforms: All
DevKey: DLP2657
Summary: Object Library - add SELECTMODE parameter to %Library.Query

Description:

The SELECTMODE parameter can now be specified for class queries of type %Library.Query. For these queries, SELECTMODE is declarative and it is the responsibility of the query author to properly format the column values according to the SELECTMODE parameter setting. If that setting is RUNTIME, then the current runtime SELECTMODE can be retrieved from $system.SQL.GetSelectMode().

The default value for SELECTMODE for queries of type %Library.Query is LOGICAL. If existing queries are having problems with client software and data formats then the existing query might have to be updated to specify a different SELECTMODE value so that the values as formatted by the query are properly recognized.


Category: SQL.GateWay
Platforms: All
DevKey: MIT1027
Summary: Avoid <SUBSCRIPT> error in JDBC Gateway if it was restarted

Description:

This change avoids a situation where an attempt to restart the JDBC Gateway could result in a <SUBSCRIPT> being generated.

Category: Object.LanguageBindings.LCB
Platforms: All
DevKey: JMM414
Summary: LCB correctly read %Time fields that were stored via SQL

Description:

This change fixes two problems with the d_time class (the projection class for the Cache %Time datatype) in C++ binding and Light C++ Binding. The first problem was that d_time::operator!=(const d_time&) always returned true. The second problem (in Light C++ Binding only) was that Light C++ Binding stored d_time in a different format (a string in "hh:mm:ss" format) from the format used by SQL and other object APIs (which store time as a string representation of the number of seconds elapsed since midnite). Therefore, times stored by LCB could not be correctly read by SQL, and vice-versa. With this change, LCB now stores times in the same format used by SQL, and can correctly read times that were stored in either format.

Category: SQL.GateWay
Platforms: All
DevKey: TAP1041
Summary: Make SQL Adapter compensate for JDBC Gateway issue where $C(0) is returned when a LOB chunk should be empty

Description:

This change makes the SQL Adapter JDBC LOB logic ignore $C(0) (Ascii NUL) if it appears as the sole content of a block of data that is not the first block. This works around an error in the lower levels of the JDBC Gateway that causes such a NUL character to be returned if there is no more data after retrieving a full chunk.

Category: SQL.ODBC
Platforms: Windows 64-bit
DevKey: JCN1177
Summary: Make sure kernel API calls use the same locale Code Page as C runtime library

Description:

This change corrects a situation in SQLServer on 64-bit Windows where different code pages could be used for character translations by the kernel and the ODBC driver resulting in "?" being displayed for unrecogniized characters.

The change causes the regional setting defined as the code page for character trranslations.

Note: This change only affects Windows applications that do not use Unicode, and require ODBC to convert to Multibyte values.

Category: Studio
Platforms: All
DevKey: DVU2812
Summary: Fix problem loading package information

Description:

This change modifies the Studio client to support loading package information by explicitly specifying the package name when using %Dictionary.PackagDefinition.

Category: Studio
Platforms: All
DevKey: DVU2821
Summary: Remove unneeded calls to COM_ITNodeManager2::CheckClassIndexUpToDate

Description:

This change corrects a memory leak that occurred when importing a large number of files in one operation.

Category: System
Platforms: All
DevKey: CDS1758
Summary: <WIDE CHAR> or invalid name with <SUBSCRIPT> or <UNDEFINED> error

Description:

When using private variables within a procedure, a <SUBSCRIPT> or <UNDEFINED> error could be reported as <WIDE CHAR> or could show an incorrect variable name in the error text.

This situation is now corrected.


Category: System
Platforms: All
DevKey: GK882
Summary: Improved resource utilization during routine and class component loading

Description:

This change modifies Caché to load the routine and object components in batch mode; after being loaded they are cached in routine buffers and not used again. It also modifies Caché to release the retained buffers after loading a routine.

Category: System
Platforms: All
DevKey: JLC1441
Summary: Fix handling of surrogate pairs in modal translations

Description:

This modification fixes a problem that could cause an access violation on 64-bit Windows if an application tried to submit a string with surrogate pairs for output translation with a table that does not support this feature (for example, JIS instead of JIS2004).

Category: System
Platforms: All
DevKey: SAP1375
Summary: Fix to clean daemon for freeing gfowner

Description:

This change causes the clean daemon to free gfowner resource properly. Previously, the resource was not properly returned.

Category: System
Platforms: DECUNIX
DevKey: SAP1377
Summary: Fix SIGUSR2 handling

Description:

SIGUSR2 appears blocked on DECUNIX clusters. This change restores its functionality.

Category: System
Platforms: HP-UX
DevKey: TRW890
Summary: Kill ISCAgent processes on HP-UX with -9

Description:

This change corrects a timing issue which prevents a single kill command from killing both ISCAgent processes on HP-UX when sent a SIGTERM. The remaining process was preventing the ISCAgent from being upgraded.

Category: System.Mirroring
Platforms: All
DevKey: JO2363
Summary: Resolve troubles with backup moving journal files to the alternate directory when the disk is full

Description:

This change corrects several known problems that occurred if the backup ran out of space to store a journal file from the primary system.

Category: System.Mirroring
Platforms: All
DevKey: JO2370
Summary: Adjust console log severity of mirror [dis|re]connect messages

Description:

When the system is configured to do so, mirroring generates the following email level alerts (severe log messages) for:
  1. a node becomes the primary (In the future this could be modified to exclude situations where the backup becomes the primary after the primary is shut down gracefully, but for now Caché generates an alert any time a node becomes the primary.)
  2. backup disconnects from primary and fails to either become the primary or reconnect as a backup
  3. system starts up and fails to become the primary or a backup. This includes async members which fail to connect to the primary at startup.

In addition there are less severe cconsole messages for:


Category: System.Mirroring
Platforms: All
DevKey: JO2372
Summary: Include ping answers when tracking time of last contact with primary

Description:

A problem has been resolved where a backup might fail to take over when agent contact required is set to no and the mirror is idle at the time of the failover.

Category: System.Mirroring
Platforms: All
DevKey: SML1255
Summary: Don't purge primary node's mirror journal files if they are needed by the backup node

Description:

This change fixes a situation where when the backup node has been down more than 14 days, the primary node might purge the journal files needed by the backup node to catchup.

Category: System.Mirroring
Platforms: Oracle Solaris
DevKey: VRN006
Summary: Fix real/effective group/user ID retrieval on Oracle Solaris, and VIP assignment on SunOS

Description:

This change corrects a problem in adding and deleting VIP scripts on SunOS where the check for running as root was improperly done.

Category: Utilities.Configuration
Platforms: All
DevKey: STC1864
Summary: Save memlock parameter correctly

Description:

When modifying the LockSharedMemory or LockTextSegment parameters in the management portal and setting the value to True, the values written to the memlock= parameter in the CPF file were incorrect. This could cause the memory to not be locked upon a subsequent restart of the system. This has been corrected.

Change Reports for Caché 2010.2.1

Category: CSP.Gateway
Platforms: All
DevKey: CMT878
Summary: Resolve a potential buffer overrun in the function responsible for deriving the path to the Gateway documentation files and templates

Description:

This correction resolves a potential buffer overrun in the function responsible for deriving the path to the Gateway documentation files and templates.

This issue only affects installations with long paths to the Gateway configuration file. Specifically, it applies to installations with paths greater than 64 characters long.


Category: Ensemble.Adapter
Platforms: All
DevKey: JN927
Summary: Handle $C(0) padded AET names in DICOM Adapter

Description:

A particular windows DICOM testing tool IQTEST.exe, sends AET names padded with $C(0), which is not recognized by the InterSystems DICOM Adapter. This change corrects this issue.

Note: The problem can be worked around by making both local and remote AET names 16 characters long. This eliminates the padding and allows successful matching


Category: Ensemble.HL7/EDI
Platforms: All
DevKey: MC1153
Summary: Improve the performance of replaceSeparators

Description:

A prior change fixed the logic of replaceSeparators. This correction changes the internal logic in replaceSeparators and replaceArrayLeftToRight to improve the efficiency of the replacement.

Category: Ensemble.HL7/EDI
Platforms: All
DevKey: TAP1072
Summary: Do custom separators translation in VDoc PropertyGet methods

Description:

The HL7 Message and other EDI VDoc classes have several standard computed properties whose values are drawn from the document content: [type] Name, Identifier, and TypeVersion. This change modifies the way these values are calculated to bypass the ReplaceSeparators() method that was used to normalize the internal structure of these values; instead it uses a simple local $TRANSLATE function call.

This change also reconciled the separators normalization done for Identifier values between SQL and object getter implementations. Formerly the reconciliation was done only in the object getter.


Category: Ensemble.ManagementPortal
Platforms: All
DevKey: HCR160
Summary: Fix links in the Ensemble message resend page

Description:

This change corrects errors in the links present on the message resend page in Ensemble.

Category: Installation.Ensemble
Platforms: All
DevKey: HCR161
Summary: Avoid some kinds of errors when copying the Ensemble portal files such as upgrade on OpenVMS

Description:

This change modifies methods CopyFile() and CopyDir() of class %File to take a new (optional) parameter indicating if the file(s) being copied should be deleted (on OpenVMS all versions will be purged) prior to the copy, and makes %EnsembleMgr use this new parameter.

Category: Installation.Windows
Platforms: All
DevKey: ALE1960
Summary: Do not allow Caché to install on Windows 2000

Description:

When attempting to run on Windows 2000 or below, the installer now displays an error message and exits.

Category: Languages.COS
Platforms: All
DevKey: GGC454
Summary: Correct reverse $ORDER with ptrie arrays and unassigned subscripts

Description:

This change corrects a problem when doing a reverse search using $ORDER in local arrays when the subscript value being searched for does not exist in the array because it was never used or has been deleted.

Category: Languages.MVBasic
Platforms: All
DevKey: SOH226
Summary: MVB performance enhancement V<-1>=expr

Description:

This change improves the performance of MV BASIC assignments of the form V<-1>=E; by recognizing and treating them as special cases.

Category: Networking
Platforms: UNIX®
DevKey: GK871
Summary: TCP send error handling

Description:

In a very rare condition on UNIX® platforms, when

when the connection is dropped, Caché may not detect the connection failure and wait forever for the write completion.


Category: Object.ActiveX
Platforms: All
DevKey: IYB708
Summary: CacheActiveX, reimplemented FileRead() and FileWrite()

Description:

Thic change adds support for unicode files in FileRead() and FileWrite() in CharStream and BinaryStream.

Category: Object.C++
Platforms: All
DevKey: IYB707
Summary: C++ binding, initialize d_timestamp from string of format YYYY-MM-DD

Description:

This change allows the D_timestamp to be initialized with a string containing only the date part of the timestamp.

Category: Object.LanguageBindings.MDS
Platforms: UNIX®
DevKey: JMM408
Summary: Allow Java eXTreme apps to be terminated with SIGINT, SIGTERM on UNIX®, without hanging Cache

Description:

This change enables Java applications using callin-based eXTreme APIs (XEP, MDS, eXTreme JDBC or eXTreme Dynamic Objects) to be interrupted/terminated using SIGINT (i.e. control C) or SIGTERM (kill -15) on UNIX® platforms, without risk of hanging the Caché instance. This change applies only to the non-threaded versions of the eXTreme APIs, and only to UNIX® platforms.

A previous change to the server-side code changed callin so that it does not block these signals, and allows users to set their own handlers for them. However, it required application-level code to explicitly block these signals in any threads that call into Caché (which is not actually possible to do at the Java level); to supply a handler which would call CacheEnd(), in a way guaranteed to be synchronized so that no callin calls were in progress in other threads; and to ensure that there was at least one thread that never called into Caché and didn't block these signals, so that the user-supplied handler would be caught in that thread. If an application did not fulfill these requirements, interrupting it could cause the Caché instance to hang, so that it needed to be shut down, or in worse cases, forced to shut down, or even required to be reinstalled.

The present change transparently implements these requirements within the eXTreme APIs, so that application code is not required to do any signal management, define any signal handlers, or do any explicit cleanup of the Caché connection when one of these signals is caught.

Details of behavior: If the application does supply its own handler for either of these signals, the application's handler will be invoked after the eXTreme handler has terminated the Caché connection. If the application has set either of these signals to be ignored (i.e., to set its action to SIG_IGN or the Java equivalent), eXTreme will not set up a handler, and will leave the signal set to be ignored (in which case, it cannot be used to interrupt the application, and there is no risk that its use will hang Caché). When the application disconnects from Caché, the actions for these signals are returned to their state prior to connecting to Caché; if the application then re-connects to Caché, the actions are again set to the eXTreme handlers.

Note that eXTreme sets SIGINT and SIGTERM to be blocked in any thread that calls into Caché, to ensure that these signals are caught in a thread that is not inside a call into Caché. Once eXTreme blocks these signals in a given thread, it never unblocks them, so it is up to the application to unblock them if it has a reason to do so. The application can safely do so, because eXTreme will re-block these signals in a given thread before each call into Caché. This is probably moot, since Java does not currently provide any API for blocking/unblocking signals in individual threads.

If a transaction is in progress when the application is interrupted, an attempt is made to roll back the transaction. However, it is not possible to guarantee that this attempt will succeed. If it fails, a message is posted to cconsole.log, and the transaction is closed.

NOTE: We do not recommend using Control-C or kill -15 as preferred ways of shutting down production applications, especially not while a transaction is in progress. This change is introduced to allow interrupting applications as a convenience during development and testing, or as a fallback approach if they are hung or sluggish, preventing use of the designed approaches to terminating them. Also note that this change does not make it ever safe or advisable to use kill -9 to terminate any eXTreme application. Signal 9 cannot be caught, ignored, or blocked, so there is no possible way of ensuring that an application can clean up its state properly when killed with signal 9. Because eXTreme APIs connect to Caché within the same process, it is essential to interrupt them, if at all, using signals that can be cleanly caught and handled.


Category: Object.Storage
Platforms: All
DevKey: DLP2682
Summary: Class Compiler - fix subnode storage retrieval for collection of objects

Description:

This change corrects an issue introduced in 2010.2 that caused %Delete to fail when the class contained a collection of objects stored in a subnode structure (array collections are stored in a subnode structure by default).

This issue affected only persistent classes using default storage that also contained a collection of objects stored in a subnode structure.


Category: Security
Platforms: All
DevKey: STC1849
Summary: Fix accvio in $system.Encryption.Base64Decode()

Description:

This fixes a problem in $SYSTEM.Encryption.Base64Decode where the process could abort if the string being decoded was at the edge of an internal memory boundary.

Category: Security
Platforms: UNIX®
DevKey: WDS367
Summary: Parallel WIJ encryption

Description:

This change allows multicore UNIX® systems to use master and slave write daemons to encrypt global buffers from encrypted databases in the WIJ image buffer(s) in parallel. Several slave write daemons will be used so the task can be completed in minimum clock time independent of process scheduling.

This currently is enabled on PowerPC and RedHat Linux 64-bit systems only.


Category: SQL
Platforms: All
DevKey: DPV3715
Summary: SQL: CopyQueryToTable correction with new cached query routine names

Description:

This change resolves a problem where $System.SQL.QueryToTable() could falsely report an erroneous line tag.

Category: SQL.Gateway
Platforms: Windows
DevKey: MIT1029
Summary: Fix setting values of parameters in SQL Gateway (8 bit Caché)

Description:

This change corrects a defect introduced in 2010.2 that made all the character parameters in linked tables (SQLGateway) fail on 8-bit Caché on Windows.

Category: SQL.ODBC
Platforms: All
DevKey: JCN1172
Summary: Fix typo in Reported value for SQLGetInfo and option 36 (MultipleResultSets)

Description:

This corrects an error that reported the value incorrectly for SQLGetInfo option 36, SQL_MULT_RESULT_SETS.

Category: SQL.ODBC
Platforms: All
DevKey: JCN1173
Summary: Consolidate RDO fix for EOF on single character data

Description:

Previously, fixes were made for a special condition in RDO where an EOF (End of File) was not being detected properly when RDO was looking for a single character of data from a column. While this is a defect in RDO, it is a heavily-used application, so a special condition was added to support this situation.

This change consolidates the previous changes to make sure all supported releases have the correct behavior. A request for one character of data with a buffer size of one character will not be null terminated and will not return a truncation error. This only applies to numeric data, and is a work around for RDO EOF issues.


Category: Studio
Platforms: All
DevKey: RAW847
Summary: Studio editor: Unexpected program exit getting selected text

Description:

Studio would unexpectedly exit when getting selected text. This has been corrected.

Category: System
Platforms: All
DevKey: CDS1756
Summary: Fix <SYSTEM> error caused by low memory during symbol table expansion

Description:

Under certain conditions when available partition memory is low, there could be an error in the symbol table leading to a <SYSTEM> error. This change prevents that situation.

Category: System
Platforms: All
DevKey: GGC452
Summary: Correct reverse $ORDER with ptrie arrays

Description:

This change corrects an issue in isolated cases whereby $ORDER with a reverse search could occasionally return an incorrect subscript key if the subscript key in the $ORDER function did not exist.

Category: System
Platforms: All
DevKey: SAP1370
Summary: A null priority argument on job command is taken for priority=0

Description:

This change corrects a situation where, in an attempt to set the priority of a job that did not supply the priority value, the null argument would be interpreted as an argument of zero.

Category: System
Platforms: All
DevKey: SAP1372
Summary: Fix end block boundary condition in FileCompact

Description:

This corrects a situation where an attempt to use FileCompact would fail if the last allocated block of the file matched the number of blocks in the file.

Category: System
Platforms: All
DevKey: SAP1374
Summary: FileCompact exits with an access violation on a mirrored database

Description:

This corrects a situation where attempting to run FileCompact on mirrored databases would sometimes cause an exit with an access violation, thereby producing a core file.

Category: System
Platforms: All
DevKey: SML1219
Summary: Correct a problem allocating memory for subscript-level map table

Description:

This corrects a situation where a failed attempt to allocate memory for the subscript-level map table was incorrectly handled.

Category: System
Platforms: All
DevKey: SML1247
Summary: Avoid access violation for clean daemon

Description:

This change avoids a clean daemon access violation while cleaning dead job. This prevents the clean daemon from being terminated by the <ACCVIO>.

Category: System
Platforms: All
DevKey: SML1249
Summary: Fix SMH defragment to avoid taking long time to coalesce the string table

Description:

This change fixes a problem that occurs when the lock memory is seriously defragmented. Under this condition, it might take a long time to complete the defragmentation and his could hang the system because some some global cache block might be owned by the job doing the defragmentation.

Category: System.I/O
Platforms: UNIX®
DevKey: HYY1588
Summary: Data corruption resulting from stream compression to files on UNIX® platforms

Description:

This change corrects a data corruption issue resulting from writing to a file with compression enabled (/GZIP[=1]) on UNIX® platforms.

A necessary condition for the problem to occur is that the file is opened in stream mode explicitly or implicitly. This means that it was NOT opened explicitly in a format that is mutually exclusive to stream mode, such as fixed-length (/FIXED), undefined (/UNDEFINED), variable record (/VARIABLE), and so on.

Under these conditions, there is an approximately 40% possibility that a 32K output (compressed) file will be corrupted.


Category: System.Journaling
Platforms: All
DevKey: HYY1594
Summary: Address error during journal switch

Description:

This change addresses an issue that could cause unexpected behavior from a process switching journal files. The situation is rare and involves journaling being disabled at a certain stage while the journal switch is being done.

Category: System.Journaling
Platforms: Windows, OpenVMS
DevKey: HYY1596
Summary: Ensure journal files expand by only 64KB chunks

Description:

This change addresses an issue on Windows and OpenVMS that could cause the current journal file to expand by a fraction of 64KB (a partial journal block) under conditions of disk space shortage. Consequences of this issue include journal daemon spinning on a CPU lock, and/or the system not recovering from the frozen state, when system is set to freeze on errors.

Category: System.Lock
Platforms: All
DevKey: SML1250
Summary: Fix ECP lock recovery left lock entries in server

Description:

This fixes a problem in ECP lock recovery when server restart or mirror failover. Some lock nodes might still exist in server's lock table while they don't exist in the clients' lock table.

Category: System.Mirroring
Platforms: All
DevKey: JO2359
Summary: Several mirror fixes related to troubles at connection time

Description:

This change addresses timing issues related to the startup of mirrored systems. Under some circumstances, a mirror configuration failed to recover properly if the backup failed to create the ack channel to the primary and the backup restarted before it could join the mirror.

Under others, the MIRRORMGR job on the primary might exit with a <SUBSCRIPT> error due to a timing issue when a backup connects. The primary would need to be restarted before it would accept any subsequent connections.


Category: System.Mirroring
Platforms: All
DevKey: JO2360
Summary: Preserve original journal file prefix when instance fails to become the primary

Description:

A problem has been fixed with instances configured with a journal file prefix where a system which failed to become the primary mirror member after switching to a mirror journal file would switch back to a non-mirror journal file which did not include the configured journal file prefix.

Category: System.Mirroring
Platforms: All
DevKey: JO2361
Summary: Keep mirror journal log in sync with files retrieved via agent

Description:

A problem has been resolved where the mirror journal log could get out of sync with the actual journal files on disk. This can happen if a journal file is retrieved but the disk becomes full and because of this the file ends up getting stored in the alternate journal location.

Category: System.Mirroring
Platforms: All
DevKey: SML1251
Summary: Fix SMP Mirror Monitor - displayed wrong SuperServer Address for 'Other' member

Description:

This corrects an issue where, in some instances, a failover attempt could transmit an incorrect SuperServer to its partner.

Category: System.Mirroring
Platforms: All
DevKey: SML1253
Summary: Fix ECP client - should not remount non-mirrored DBs during mirror failover

Description:

This fixed a problem on mirror failover while an ECP client connected to the mirror and mounted non- mirrored DBs (e.g. :ds:DBNAME or cachetemp directory path) on the mirror primary. If the two mirror members happened to be in the same machine, then the other member might not be restarted if the cachetemp was mounted.

Category: System.Shadowing
Platforms: All
DevKey: HYY1597
Summary: Directory info possibly missing from shadow copies of journal files

Description:

On a Caché system used as source of shadow data, if the total length of the mounted database paths is near or over 16KB, the shadow copy of a source journal file would miss the path of any source database mounted after the shadow copy is created.

This change addresses that issue. The source of shadowing will be updated with subsequent changes.


Category: System.Shutdown
Platforms: All
DevKey: SAP1362
Summary: Force not running after shutdown if process does not quit

Description:

During a system shutdown, if any process is "jammed", so that it does not shutdown normally, cforce is supposed to be called to clean up the process. This was not happening, so that the process that was "jammed" was left behind after a shutdown. If the process is one of the WD or JD, restart will fail; but in any case, it could cause shared memory to not be released, so that there is not sufficient shared memory to restart at the desired level.

This change prevents that situation.


Category: Utilities
Platforms: All
DevKey: RJF139
Summary: Cstat self-diagnostic may incorrectly detect a shared owner of a buffer

Description:

This change corrects an error in the cstat self-diagnostic facility. If TRACEPGSHARED was enabled, the cstat self-diagnosis for system hangs (cstat -S option) may falsely detect a job as one of the shared owners of a buffer that the job does not actually own.

Category: Utilities
Platforms: OpenVMS
DevKey: STC1847
Summary: Only keep one CACHE.CPF file on OpenVMS when edited

Description:

A change has been made so that on OpenVMS, multiple versions Caché only preserves one version of the file.


© 2011, InterSystems Corporation. All rights reserved.