Motor Module R6-9 Release Notes =============================================================================== The motor module software in this release is compatible with EPICS base R3-14-12-3. See the <motor>/configure/RELEASE file for support module version dependencies. Contents ======== This <supporttop> contains the following motor record related items: - motor database and record support (<motor>/motorApp/MotorSrc). - Model (or phase) #1, #2 and #3 device/driver support (<motor>/motorApp/MotorSrc). - device/driver support for various manufactures motor controllers (in manufacture specific directories; e.g., <motor>/motorApp/OmsSrc, <motor>/motorApp/NewportSrc). - motor record and device/driver level documentation (<motor>/documentation). - two example applications; one without ASYN (i.e. motorExApp/NoMPF) and one with ASYN (i.e., motorExApp/WithMPF). See the README files under <motor>/iocBoot/* for configuration instructions. - Back Up and Restore Tool (BURT) files (in <motor>/motorApp/op/burt). - medm displays (<motor>/motorApp/op/adl). - CSS/BOY displays (<motor>/motorApp/op/opi). - caQtDM displays (<motor>/motorApp/op/adl/ui). Any of the manufacture specific device/driver libraries can be omitted from the build by commenting out the appropriate line in <motor>/motorApp/Makefile; see "Configuration" below. In addition, valuable device information can be found in the README files located in many of the manufacture specific directories. Configuration ============= The following files can be edited to tailor the distribution to site specific needs. See individual files for instructions. - <motor>/configure/RELEASE: Define location of external products. If only EPICS_BASE is defined, then only the following libraries are built; libmotor, libsoftMotor and liboms. (Although it is built, liboms is for VxWorks targets only if ASYN is undefined). For any motor controllers requiring serial or GPIB communication, ASYN is required. - <motor>/motorApp/Makefile: Defines which manufacture specific directories to build. For example, commenting out these lines #!DIRS += NewportSrc #!NewportSrc_DEPEND_DIRS = MotorSrc will result in skipping all the Newport controllers from the build. - ./Makefile: uncomment the following to build example applications. #!DIRS += motorExApp iocBoot #!motorExApp_DEPEND_DIRS = motorApp #!iocBoot_DEPEND_DIRS = motorExApp Known Problems ============== 1) The PAUSE function of the SPMG field only works if the RTRY field is nonzero. This bug existed as far back as V3.3 of the motor record. 2) MM4005 only. On the first attempt to move off an activated limit switch, the motor moves to where it was commanded. However, the motor record's positions (both target and readback) do not reflect the move. This is because of the following sequence of events: - a limit (i.e., laser light beam) violation occurs. The Newport controller turns motor power off. - the axis stops at position X. - a move command is issued in the opposite direction. - after a delay of between 16.67 ms and 33.33 ms, a motor status (i.e., MS) query is issued to the MM4005. - the motor status response indicates the axis is NOT in motion and motor power is OFF (the motor record interprets this as "Done Moving" true). - a "read actual positions" command is issued. - the actual position response indicates the axis is still at position X. - the controller turns motor power on and the axis moves to the requested position. 3) The OMS VME58 servo motor controller board (i.e., model -8S) is unable to move off an activated limit switch. Users are advised to avoid this situation. This problem is fixed with the MAXv model. 4) With R5-3 of the motorRecord, negative encoder resolutions (ERES) are supported. This allows the user to change the sign of ERES rather than reverse encoder wires when the motor and encoder direction are reversed. There is a peculiarity with the OMS (sans MAXv) controller boards when they are configured with MRES and ERES of opposite polarity. Since both the commanded and feedback positions are set with the same command (LP), the user must enter the opposite polarity when setting the OMS motor controllers position. For example, if MRES is positive and ERES is negative and the user wants to set the current position to 10.00 inches, then -10.00 must be entered in the VAL or DVAL field. This limitation does not apply to the MAXv model after release R6-7. 5) There are several known problems with the status update field (STUP); - the motor record gets stuck in the moving state (i.e., DMOV=0) if a STUP request occurs at the same time as device support reports motion complete (i.e., RA_DONE bit in MSTA field). - a STUP request during a jog results in the motor stopping, then resuming the jog. - if the motor record's SCAN field is set to periodic scan, the record's status is periodically updated unless the motor is moving. In other words, the status update is skipped when DMOV=0 and record is processed from a periodic scan. 6) The MM4000 sets its' "Axis in Motion" status bit (MS command) false before the target position (as read by the TP command) is reached. This can appear to the motor record as a following error causing a needless retry if retries are enabled. 7) Backlash and retries do not work with the Physik Instrumente (PI) GmbH & Co. model C-862 controller. The backlash and retry move commands are (for some unknown reason) ignored and several subsequent status request result in communication timeouts. 8) The OMS VME58 controller ignores its' Velocity Base command (VB) on the up ramp of a home search operation; but not on the down ramp. 9) When the LOCK field is set to YES for a motor with soft-channel device support, the DMOV field only indicates motion for soft-motor-initiated moves. 10) There are a number of improvements with R6-8 in how the motor record support soft-travel limits (LVIO field). But there are also two known problems that may remain known limitations until signifiant changes are again made to the motor record. These limitation are as follows: - Tweaking very small increments with UEIP = Yes while in the invalid range of the soft-travel limits may put the motor record in a state where the user cannot tweak in either direction. The solution is to either jog the motor towards the valid range or increase the tweak increment value (TWV field). - Tapping the Jog button can cause the motor to move past the soft-travel limit when backlash is nonzero. Modification Log for R6-9 ========================= 1) Kevin Peterson added support for the Micronix MMC-200 & MMC-100 controllers. Files added: motorApp/MicronixSrc motorApp/MicronixSrc/MMC200Driver.h motorApp/MicronixSrc/MMC200Driver.cpp motorApp/MicronixSrc/Makefile motorApp/MicronixSrc/MicronixSupport.dbd iocBoot/iocWithAsyn/motor.cmd.mmc200 iocBoot/iocWithAsyn/motor.substitutions.mmc200 Files modified: motorApp/Makefile 2) Kevin Peterson added an asyn (model 3) driver for the Micro MVP2001. Files added: motorApp/MicroMoSrc/MVP2001Driver.cpp motorApp/MicroMoSrc/MVP2001Driver.h 3) Mark Rivers fixed bugs in motorApp/AcsSrc/MCB4BDriver.[h,cpp] It was sending E query to read motor current status, should be W query 4) Mark Rivers fixed bugs in asynMotorAxis, asynMotorController, MCB4BDriver, ACRMotorDirver Added epicsShareClass to avoid errors when building dynamically on Windows Added destructor 5) Matt Pearson added features to XPSController and XPSAxis Added support for reading the XPS positioner status string in XPSAxis, and adding it to the parameter library. Reverted back to the old definition of moving axis in the poller in XPSAxis.cpp. Made the new method, of checking the socket return value, an option which is enabled by using a new function called XPSEnableMovingMode. Added the ability to run a TCL script. Added a Db template to set and execute a TCL script. 6) Mark Rivers fixed bugs in MclennanSrc/devPM304.cc, drvPM304.cc It was passing a const char* pointer to epicsStrtok_r, which is incorrect and crashes on some systems. Protect against dereferencing null pointer, was crashing on Linux 7) Changes were made to the Model 1 OMS MAXv driver to eliminate "Command Error" messages. At the suggestion of Pro-Dex, all commands are now terminated with a ';' character. In addition, the motor record now always sends the SET_VELOCITY command before issuing a SET_VEL_BASE command. This prevents MAXv errors where the controller checks that BASE < SLEW. (There is some speculation that excessive MAXv "Command Error" messages may be causing "Watchdog Timeout" errors). Files modified: motorApp/OmsSrc/drvMAXv.cc motorApp/MotorSrc/motorRecord.cc 8) Moved CA posting of changes to the RMP, REP and RVEL fields from motor record to device support update_values(). This eliminates posting's with the same value and is more efficient. Files modified: motorApp/MotorSrc/motorRecord.cc motorApp/MotorSrc/devMotorAsyn.c motorApp/MotorSrc/motordevCom.cc 9) Kevin Peterson added support for rotary stages to the SmarAct MCS driver Files modified: motorApp/SmarActMCSSrc/smarActMCSMotorDriver.cpp motorApp/SmarActMCSSrc/smarActMCSMotorDriver.h 10) Kevin Peterson made the following improvments to motorUtil: (1) the listMovingMotors function is now registered with the iocsh, so non-VxWorks iocs can use it and (2) the name of the motor is written to a waveform record, $(P)movingDiff, when its DMOV field changes, allowing smart clients to maintain a list of moving motors. Modification Log for R6-8 ========================= 1) Bug fix for Aerotech Ensemble jog not terminating when jog request is relinquished. The FREERUN command does not activate PLANSTATUS's move_active indicator. The driver must check both PLANESTATUS and AXISSTATUS for active move. Restored home search from EPICS function. The Aerotech Ensemble example program, HomeAsync.abx, must be downloaded and the Parameters>System>TaskExecutionSetup parameter must be set to enable Auxiliary Task execution. Replaced "stepSize > 0.0" test with ReverseMotionDirection parameter to determine if the programming direction of an axis has been reversed. File modified: motorApp/AerotechSrc/drvEnsembleAsyn.cc 2) Bug fix for Schneider Electric MDrive "PR PN" response overflows input buffer. BUFF_SIZE increased from 13 to 80 bytes. Increased timeout from 1 to 2 seconds to accomodate slow "PR PN" response. Buffer flush added to accomodate extra "\r\n" from "PR PN" response. Eliminated compiler warnings on MDrive_axis[]. File modified: motorApp/ImsSrc/drvMDrive.cc 3) Kevin Peterson's bug fix for the SYNC field failing to update the target position of motors with soft-channel device support. File modified: motorApp/MotorSrc/motorRecord.cc 4) The stepsPerUnit argument of XPSConfigAxis in the model 2 asyn XPS driver has been changed from an int to a string. Files modified: motorApp/NewportSrc/drvXPSAsyn.c motorApp/NewportSrc/drvXPSAsyn.h 5) Added xpsSlave.st to motorApp/NewportSrc to allow master/slave mode to be used with any version of the XPS support. 6) Changed the way the Newport ESP300 driver handles communicating with the controller in EGU units. Instead of using the controllers resolution as the scaler for EGUtoRAWbacktoEGU conversion, the driver uses the motor record's MRES. Files modified: motorApp/NewportSrc/{dev/drv}ESP300.cc 7) Added asyn motor driver support to read actual raw velocity (RVEL field). File modified: motorApp/MotorSrc - motor_interface.h, motordrvCom.h, drvMotorAsyn.c 8) Added support for the nPoint C300: Files added: motorApp/NPointSrc motorApp/NPointSrc/C300MotorDriver.cpp motorApp/NPointSrc/C300MotorDriver.h motorApp/NPointSrc/Makefile motorApp/NPointSrc/NPointMotorSupport.dbd 9) Added RTRY field to asyn_motor.db with default value of 10 to allow new support the option of overriding the number of retries without breaking existing support. 10) Added support for the Newport Hexapod (HXP): Files added: iocBoot/iocWithAsyn/motor.substitutions.hxp iocBoot/iocWithAsyn/motor.cmd.hxp motorApp/Db/HXP_{extra,coords}.db motorApp/NewportSrc/HXPDriver.{cpp,h} motorApp/NewportSrc/hxp_drivers.{cpp,h} motorApp/NewportSrc/hxp_error.h motorApp/op/adl/HXP_{extra,motors,moveAll,coordSys}.adl 11) Significant changes were made to the motor record: - Ignore retry deadband (RDBD) on 1st move. - Toggle DMOV on tweaks (TWF/TWR). - Remove soft travel-limit error checks from home search request. - Moved synch'ing target position with readback to a subroutine. - Allow moving [new target position (DVAL/VAL/RVAL), relative move (RLV), jog or home search] out of the invalid soft-limit travel range toward the valid range. - Added an "In-position" retry mode (RMOD). The In-position RMOD does send any position commands during retries; it simply waits for the position error (DIFF) to be less than the retry deadband (RDBD). It is to be used with a non-zero Readback settle time (DLY) value. Also see "Known Problems" above, item #10. File modified: motorApp/MotorSrc - motorRecord.cc, motorRecord.dbd Modification Log for R6-7 ========================= 1) Since the purpose of a Home search is to establish an absolute reference position, the soft travel limits are not valid during a home search operation. Accordingly, the motor record's soft travel limit error check is now disabled during a home search operation. In addition, the motor record was not setting an acceleration rate for a home search. It now uses the home velocity (HVEL), base velocity (BVEL) and accel. time (ACCL) fields to set a home acceleration rate. File modified: motorApp/MotorSrc/motorRecord.cc 2) If an OMS VME58 board rebooted (as described under item #12 R6-6), it could end up in an endless loop in the driver's send_mess() function. Add a counter to prevent the endless loop. File modified: motorApp/OmsSrc/drvOms58.cc 3) Added OMS MAXv device drive support for MRES and ERES having different polarities. See "Known Problems" item #4). Files modified: motorApp/OmsSrc/devOmsCom.cc motorApp/OmsSrc/drvMAXv.cc 4) With this release, the Aerotech Ensemble driver only supports 4.01.00 version firmware and above. In order to support SCURVE trajectories, the move commands have been changed from MOVE[ABS/INC] to LINEAR. Currently, the SCURVE command can only be set from an asyn record (e.g., SCURVE 75). Modification Log from R6-5 to R6-6 ================================== 1) Aerotech Ensemble asyn motor driver would crash the IOC at boot-up if the Ensemble was not powered up and able to communicate. Files modified: drvEnsembleAsyn.cc 2) Aerotech Ensemble EOT limit switch status was not available except via an Ensemble fault condition. With this release the status of the EOT limit switches are always available. Files modified: drvEnsembleAsyn.cc; add Parameters.h 3) Jens Eden's (PTB) added support for the OMS MAXnet motor controller with an asyn motor port driver. Files added to OmsSrc: drvMAXnetAsyn.h, drvMAXnetAsyn.cc, README_MAXnet 4) For OMS MAXv firmware ver:1.33 and above, the EPICS driver reads the MAXv's Watchdog Timeout Counter at bootup, and with every motor status update. If the Counter is nonzero, an error message is sent to both the errlog task and the console. Since a watchdog timer trip indicates that the MAXv has rebooted and no longer has valid motor positions, the controller is disabled and is no longer available to EPICS until after the VME crate has been rebooted. Other MAXv boards in the system are unaffected by this scenario. To better communicate this problem to the user, several medm displays have been changed. Small displays (motorx_tiny.adl, motorx.adl) will show a yellow border around their position readback values. Larger displays (motorx_more.adl, motorx_all.adl) will display the message "Controller Error" in yellow. The following error message at the console and/or in the IOC errlog is definitive; "***MAXv card #<card> Disabled*** Watchdog Timeout CTR =<ctr>" motor_end_trans_com() was modified to set RA_PROBLEM rather than CNTRL_COMM_ERR when a NULL motor_state[] pointer is detected. Files modified: motordevCom.cc, drvMAXv.cc, motorx_tiny.adl, motorx.adl, motorx_more.adl 5) The GNU preprocessor assertions in motor.h are deprecated with the VxWorks 6.x compiler. Test for CPU macros that are compatible with VxWorks 6.x have been added. This change prevents an "Error: unknown bit order!" compiler error with VxWorks 6.x. File modified: motorApp/MotorSrc/motor.h 6) Wang Xiaoqiang (PSI) bug fix for Aerotech Ensemble communication problem with Ensemble firmware 2.54.004 and above. Redundant EOS append in sendAndReceive() removed. File modified: drvEnsembleAsyn.cc 7) Minor bug fix to ACS Motion Control, SPiiPlus controller. Uninitialized data area would sometimes cause a crash at iocInit time. Files modified: AcsTech80Src/drvSPiiPlus.cc AcsTech80Src/Makefile 8) Matthew Pearson's (Diamond) bug fix for deferred moves broken in the Motor Simulation (devMotorSim) device driver. File modified: MotorSimSrc/drvMotorSim.c 9) Added error check for valid acceleration rate on STOP command to OMS device support. This prevents "command error" messages when VBAS = VELO and a STOP command is issued. File modified: OmsSrc/devOmsCom.cc 10) There is a problem with initiating a home search with the Aerotech Ensemble motor controller with EPICS. The problem is that the EPICS Ensemble driver uses Aerotech's ASCII communication protocol and that protocol blocks all communication on ASCII communication ports during a home search. Consequently, once a home search is started from EPICS, it is unable to stop it. With this release, the home search function is commented out of the Ensemble driver. Users that need to perform a home search should do it from Aerotech's IDE software, which can abort a home search. File modified: AerotechSrc/drvEnsembleAsyn.cc 11) Since the Ensemble network connection requires period communication from the host to prevent the Ensemble from closing the network socket, the Ensemble support based on the old device driver architecture (phase 1) was removed with this release. The asyn motor architecture supports continuous, periodic updates; the old architecture does not. Files deleted: AerotechSrc/[devEnsemble.cc, drvEnsemble.cc, drvEnsemble.h] Files modified: AerotechSrc/[AerotechRegister.h, Makefile, devAerotech.dbd] 12) A reboot error check was added to the OMS VME58 device driver. When the reboot error check detects that a VME58 board has rebooted since the last power-cycle or VME SysReset, and no longer has valid motor positions, the controller is disabled and is no longer available to EPICS until after the VME crate has been rebooted. Other VME58 boards in the system are unaffected by this scenario. The following error message is sent to the IOC error log; ***VME58 card #0 Disabled*** Reboot Detected. Files modified: OmsSrc/[drvOms58.cc, drvOms58.h] 13) Michael Davidsaver (BNL) discovered buffer overflow vulnerabilities in the OMS MAXv driver. Added buffer overflow error checks in MAXvConfig()'s configuration string argument and in readbuf(). Added a counter to send_mess()'s "waiting for message acknowledgement" loop to prevent infinite loop when MAXv board is not responding. File modified: OmsSrc/drvMAXv.cc 14) OMS MAXv - Increase maximum configuration string size from 150 to 300 bytes. - Increase all receive buffer sizes to same 300 bytes. - Add error checks for buffer overflow in MAXvConfig() and in readbuf(). - Buffer overflow error checks Modification Log from R6-4 to R6-5 ================================== 1) Fixed 64 bit compile problems with PI E816 and Aerotech Ensemble. Files modified: devPIE816.cc and devEnsemble.cc 2) Dirk Zimoch (PSI) fixed a bug in the OMS MAXv driver that caused the set_status() function to overwrite the home switch status in the response string. File modified: drvMAXv.cc 3) Matthew Pearson (Diamond) fixed a bug on Newport XPS and MM4000 asyn motor port drives that was causing idle polling to interfere with setting positions and prevented auto save/restore from working. Files modified: drvMM4000Asyn.c, drvXPSAsyn.c, drvMotorSim.c and drvANC150Asyn.cc; added epicsMutex[Lock/Unlock] to motorAxisSetDouble(). 4) A problem was introduced in R6-4 (fixed in R6-4-2) of the old motor record device drive architecture. If during the move of one or more motors the motor task did not issue an OS delay during status updates, it could potentially not respond to any further motor commands. Files modified: - MotorSrc/motordrvCom.cc; always check for incoming messages. - OmsSrc/drvOms58.cc; reduced start_status() delays. 5) Modifications were made to motorRecord.cc:do_work() with R6-4 to limit the ramifications of ORing MIP_MOVE with MIP_RETRY. Unfortunately, the effect of one of those changes prevented the motor from doing its' backlash move when a motor move was interrupted by "New Target Monitoring". The user would see a "tdir" message in the iocsh and the motor would move, not to the target position, but to the target minus the backlash distance. File modified: do_work() in motorRecord.cc; unconditionally set the postprocess indicator TRUE so postProcess() can do the backlash move. 6) Prevent multiple STOP commands. File modified: motorRecord.cc:process(); added check for !MIP_STOP to NTM logic. 7) The asynMotor device support would erroneously leave a motor-in-motion indicator on if the motor record issued a LOAD_POS command before the 2nd pass of device support initialization. Added logic to devMotorAsyn.c:asynCallback() to prevent moveRequestPending from being left in a nonzero state after the execution of a LOAD_POS command done as a result of save/restore during boot-up. File modified: devMotorAsyn.c:asynCallback() 8) Aerotech Ensemble device driver fixes for incorrect Jog speeds, support for a negative PosScaleFactor parameter and detecting maximum travel limit switch faults. Files modified: devEnsemble.cc, drvEnsemble.h, drvEnsemble.cc 9) Moved preprocessor assertions in motor.h to the end of the conditional logic to avoid MSVC compiler errors. File modified: MotorSrc/motor.h 10) Matthew Pearson's (Diamond) fix for the motor simulator getting stuck in the Moving state after multiple LOAD_POS commands to the same position. File modified: MotorSrc/devMotorAsyn.c; set needUpdate = 1 in asynCallback() before dbProcess() call. 11) A consequence of the fix for item #10 above caused the motor record to see RA_DONE in the MSTA field True on the 1st status update after a move; whether or not the motor was done moving. Matthew Pearson's fix is to set motorAxisDone False in motorAxisDrvSET_t functions that start motion (motorAxisHome, motorAxisMove, motorAxisVelocityMove) and force a status update with a motorParam->callCallback(pAxis->params) call. Files modified: - NewportSrc/drvMM4000Asyn.c - AtttoCube/drvANC150.cc - MotorSimSrc/drvMotorSim.c 12) Removed the OMSL field from the motorx_all.adl medm display to prevent confusion with motor position closed-loop control. File modified: motorApp/op/adl/motorx_all.adl 13) An error was introduced with R5-3 when the STUP field was added (item #4 under R5-3) that resulted in the PACT field being cleared before recGblGetTimeStamp(), alarm_sub() and monitor() were called. File modified: process() in motorRecord.cc 14) Made OMS device driver Setup and Configure shell command error messages more prominent. Files modified: <driver>Setup() drvMAXv.cc, drvOms58.cc and drvOms.cc 15) OMS MAXv driver changes from Austen Rose (Diamond) that support backwards compatibility with ver:1.29 and earlier MAXv firmware. OMS changed their line terminator from '<LF><NULL>' to '<LF>' for RA, QA, EA and RL command with ver:1.30 firmware. File modified: recv_mess() in OmsSrc/drvMAXv.cc 16) Bug fixes for Newport PM500 driver not initializing the MSTA field correctly. Added support for CNEN field. Files modified: devPM500.cc, drvPM500.cc, motorRecord.dbd 17) Mark Rivers made numerous changes to eliminate 64-bit compiler warning messages. 18) Applied item #11 above to the Newport XPS driver. File modified: NewportSrc/drvXPSAsyn.c 19) attocube ANC150 driver bug fixes for multi-axis applications not reading frequency and 'set position' not setting val/dval/rval. File modified: motorApp/AttocubeSrc/drvANC150Asyn.cc 20) Bug fix (reported by Pawel Jalocha) for homing in the wrong direction when MRES < 0. File modified: Reverse Home direction commands based on MRES < 0 in do_work() and postProcess(). 21) Bug fix for Newport MM4000 asyn motor support. The IOC would crash if, for any reason, communication was not established at bootup. File modified: null pointer error check added to drvMM4000Asyn.cc:sendOnly(). 22) Newport MM4000 controller (old driver architecture) bug fix for controller error check overwriting position buffer. File modified: motorApp/NewportSrc/drvMM4000.cc 23) Removed support for Highland Technologies model V540 Directory removed: motorApp/V544Src 24) Bug fix for backlash not being done when MRES<0 and DIR="Neg". File modified: motorApp/MotorSrc/motorRecord.cc 25) Removed the depreciated motor resolution field (RES) from the motor record database definition. The RES field has been depreciated by the MRES field since R4-5 Files modified: motorApp/MotorSrc/motorRecord.cc motorApp/MotorSrc/motorRecord.dbd 26) Removed unused, and under used, MMAP and NMAP indicators. File modified: motorApp/MotorSrc/motorRecord.cc 27) Two new Aerotech device drives were added. An 'asyn motor' version of the Ensemble and a Soloist under the old driver architecture. Files added: devSoloist.cc, drvSoloist.cc, drvSoloist.h drvEnsembleAsyn.cc, drvEnsembleAsyn.h 28) Matthew Pearson (Diamond) added support for the ADEL and MDEL fields. Files modified: motorRecord.cc, motorRecord.dbd 29) Added synchronize field (SYNC) that sets VAL/DVAL/RVAL to RBV/DRBV/RRBV. Files modified: motorRecord.cc, motorRecord.dbd Modification Log from R6-3 to R6-4 ================================== 1) The motor record was not posting raw actual velocity changes (RVEL field). File modified: motor_update_values() in motordevCom.cc 2) A problem with OMS VME58 2.24-8S version firmware and all 2.35 firmware versions has arisen since the modifications described in item #8 under R6-3 were made. When the user sets the motor record's position, the previous target and readback positions are read from the controller on the next update. This occurs with the previous release (R6-3) because the "stale data delay" was changed to zero for the drvOms58 driver. With this release the driver searches all VME58 board ID's for either 2.24-8S or any 2.35 version. If any board is found, the "stale data delay" is set to a non-zero value. This problem is similar to the "intermittent wrong LS status" problem, but in this case it is the Load Position (LOAD_POS) motor command that results in "stale data" being read by the driver. After extensive testing, I am unable to re-create the original "intermittent wrong LS status" problem. File modified: motor_init() in motorApp/OmsSrc/drvOms58.cc. Added ID search; if found, set "update_delay" non-zero. 3) A problem was reported by Emma Shepherd (Diamond) with the previous release if the "Use RDBL Link" field (URIP) was set to "Yes". The NTM logic was sending stop commands and issuing the "tdir=.." message to the console if the RDBL link was used. This error was the result of changing the NTM logic as described in item #11 under R6-3 modifications. With this release, the NTM logic is restored to using feedback rather than reference positions. In addition, an "NTM deadband factor" field (NTMF) is added to allow the user to set the NTM deadband; NTM deadband = NTMF * (|BDST| + RDBD) NTMF must be >= 2. If properly configured, the NTM deadband prevents NTM logic from issuing a STOP command at the end of a DC motor move that overshoots its' target position. Files modified: - MotorSrc/motorRecord.dbd; NTMF added. - MotorSrc/motorRecord.cc; NTM logic uses deadband based on NTMF. 4) Changed the "update delay" for OMS MAXv's from 10ms to zero. File modified: - motorApp/OmsSrc/drvMAXv.cc; set "update_delay" member of "targs" to zero. 5) Major changes have been made to the Access Security Level (ASL) attribute of the motor record fields. With previous releases, the following fields were set to ASL=0; FOF, VOF, SSET, SUSE, VBAS, VMAX, SBAS, SMAX, UREV and MRES. All other fields were set to ASL=1 by default. With this release, the policy is to set all the fields that the user requires to do the following to ASL = 0; - move a motor; (VAL, DVAL, RVAL, TWF, TWR, TWV, RLV, JOGF, JOGR) - stop a motor; (STOP, SPMG) - enable/disable motor torque; (CNEN) - set the position of a motor; (SSET, SUSE, SET) - set the "user" offset of a motor; (FOF, VOF, FOFF,OFF) - update the status of a motor; (STUP) - adjust or turn off backlash; (BDST) All other fields are set to ASL = 1. This means that out of the list of fields that were previously set to ASL=0; VBAS, VMAX, SBAS, SMAX, UREV and MRES are now set to ASL=1. File modified: - MotorSrc/motorRecord.dbd 6) Previous releases of the motor record distribution would not compile for 64-bit platforms. Numerous minor modifications were made for this release to attain 64-bit compatibility. Note that at the time of writing (03/14/08), this release was successfully compiled on a Linux Fedora Core 6 x86_64 host using gcc version 4.1.2, but there are bugs. Since EPICS base (R3.14.9) has not had all the bugs wrung out (Mantis ID's #309, #310), there are no immediate plans to debug 64-bit related problems. Files modified: - too numerous to mention. 7) Fixed a bug that was setting the Dial Readback Value (DRBV) based on RRBV when URIP = Yes. See "Getting Started with EPICS"/"Motor Record"/ "Feedback data flow" diagram for details. File modified: process_motor_info() in motorRecord.cc 8) Added support to the asyn motor device driver architecture for the MR GET_INFO command. Modifications in <motor>/motorApp/MotorSrc: - added a new paramLib function member (forceCallback) to paramSupport in paramLib.h - added new parameter (forceCallback) to paramList and a new function (paramForceCallback) in paramLib.c. paramForceCallback()'s only function is to set "forceCallback" so that the MR gets processed. - added a new motorAxisDrvSET_t member (forceCallback) to motor_interface.h. - added a new asyn motorCommand (motorUpStatus) in drvMotorAsyn.h - changed the GET_INFO case in devMotorAsyn.c build_trans() to use the int32Type interface and the motorUpStatus command. - added a motorUpStatus case to the command switch in devMotorAsyn.c asynCallback(). - added a motorUpStatus case to the command switch in writeInt32() of drvMotorAsyn.c which calls the driver's forceCallback(). Modifications to <motor>/motorApp/NewportSrc/drvMM4000Asyn.c: - added motorAxisforceCallback() to motorMM4000's motorAxisDrvSET_t. - implemented the motorAxisPosition command in motorAxisSetDouble(). - added motorAxisforceCallback() which calls forceCallback() to set the forceCallback parameter and then signals the poller task. 9) The OMS MAXv handles execution of queued acceleration commands differently than earlier controllers. In the case where the slew acceleration (ACCL field) had been overridden by an acceleration command primitive in the Pre-move field (PREM), this resulted in the inability to restore the slew acceleration when a stop command was issued. With this release, the common OMS device support (devOmsCom.cc) checks the controller ID (ident) for a MAXv when a STOP command is issued and if a MAXv is found, extra controller commands are added to force the restoration of the slew acceleration. File modified: OmsSrc/devOmsCom.cc 10) Previous releases had a problem with the OMS MAXv device driver when it was configured for more than one board, and, either A24 or A32 addressing was specified. The driver was not sizing the address space occupied by each MAXv correctly. Files modified: OmsSrc/drvMAXv.[cc/h] 11) Fixed OMS MAXv error on ER command. Replaced UU1.0 command with UF. File modified: OmsSrc/devOmsCom.cc 12) Fixed OMS MAXv bug with incorrect scaling of PID parameters reported by Jerome Hosselet (CNRS). File modified: OmsSrc/devOmsCom.cc 13) motorUtilAux.cc was not declaring pdbbase correctly. Consequently, link errors were occuring with Visual C++. File modified: MotorSrc/motorUtilAux.cc 14) With previous releases, motor_task() would not allow the next polling update to take place without some delay, even if the last update had taken longer than the total time required for the polling rate delay. With this release the motor_task() skips the delay if either the time elapsed since last update is > polling rate delay or if the wait time is < 1/2 the epicsThreadSleepQuantum. File modified: MotorSrc/motordrvCom.cc 15) The declaration for scanOnce was changed from (void * precord) to (struct dbCommon *) with EPICS base R3.14.10, causing a compile error in motorRecord.cc. File modified: MotorSrc/motorRecord.cc 16) System generation files (Makefiles and "configure" files) have been updated based on the makeBaseApp utility. In addition, this release supports the parallel make feature available starting with R3.14.10. Files modified: - all "configure" files. - the "top" and "motorApp" Makefiles. 17) Ron Sluiter added asyn motor support for the attocube systems AG ANC150 Piezo Step Controller. Files modified: added the "AttocubeSrc" directory 18) Chad Weimer (Aerotech) added support for Aerotech's Ensemble family of digital servo controllers. Files modified: added the "AerotechSrc" directory 19) John Hammonds added support of the Physik Instrumente (PI) GmbH & Co. E-816 motor controller. Files modified: added devPIE816.cc, drvPIE816 and drvPIE816.h to the PiSrc directory 20) Added a field (RMOD) that allows the user to select different ways of calculating the retry distance move. The default mode (Unity) moves the motor a relative distance based on the dial error (DIFF field). Badly behaved devices (piezo motors) can oscillate around their target position in this mode. Hence, two other modes were added to allow a decreasing response from the motor record after each retry. The Arithmetic mode generates an arithmetic sequence of corrections. For example, if the max. retry count (RTRY) is 10, then the retries will proceed as follows; DIFF * (1.0), DIFF * (9/10), DIFF * (8/10), etc. The Geometric mode generates a geometric sequence with a 1/2 common factor of corrections. For example, if the max. retry count is 10, then the retries will proceed as follows; DIFF * (1.0), DIFF * (1/2) DIFF * (1/4), DIFF * (1/8), etc. Files modified: - added the "RMOD" to MotorSrc/motorRecord.dbd - RMOD support changes to MotorSrc/motorRecord.cc Modification Log from R6-2 to R6-3 ================================== 1) <motor>/motorApp/NewportSrc was not building for the solaris-sparc-gnu target. Three changes were made to test the above change for the solaris-sparc (SUNWspro) target and to make the motor record distribution solaris-sparc (SUNWspro) compatible. Files modified: - "XPSGatheringMain_SYS_LIBS_solaris += socket nsl" added to motorApp/NewportSrc/Makefile. - "motorSimSupport_LIBS += motor" added to motorApp/MotorSimSrc/Makefile. - modified "Debug" statement arguments in motorApp/NewFocusSrc/drvPMNC87xx.cc - "oms_LIBS += asyn" added to motorApp/OmsSrc/Makefile. 2) Mark Rivers found and fixed a bug in the motor record; RDBD was being used in motordevCom.cc's motor_init_record_com() before the RDBD validation check in motorRecord.cc's init_record(). This resulted in motor positions not being initialized from save/restore at boot-up if RDBD was not included in a save/restore save set. File modified: the enforceMinRetryDeadband() call in init_record() was moved to before the call to device support init_record. 3) Added Shifu Xu's support for Animatics Corporation SmartMotor. Directory added: motorApp/SmartMotorSrc 4) A bug was introduced into the shell command "motorUtilInit()" affecting these versions of the motor distribution; R6-2, R6-2-1 and R6-2-2. This bug resulted in the erroneous error message; "motorUtilInit: Prefix %c: has more than 53 characters. Exiting". File modified: motorApp/MotorSrc/motorUtil.cc 5) The "alldone" PV in motorUtil.db defaulted to the "moving" state between "iocInit" and "motorUtilInit", giving the false indication that motors were moving during boot-up. The "alldone" PV now defaults to the "done" state. File modified: motorApp/Db/motorUtil.db 6) Added Jens Eden's (BESSY) modifications to the OMS MAXv driver. - register iocsh commands. - added USE_DEVLIB with RTEMS conditional. - replaced errlogPrintf calls in ISR with epicsInterruptContextMessage calls. File modified: motorApp/OmsSrc/drvMAXv.cc 7) OMS MAXv driver clean-up; made send_mess() and recv_mess() non-global and removed unneeded stub start_status(). File modified: motorApp/OmsSrc/drvMAXv.cc 8) The OMS VME58 "stale data" problem referred to in item #4 under R5-7 was caused by communicating via the ASCII commands while the DPRAM was updating. With this release the OMS VME58 driver's "stale data delay" is set to zero. In addition, a "Work around for intermittent wrong LS status" that occurred only with version 2.35 firmware is removed. Finally, start_status() is modified to wait for DPRAM update before exiting. File modified: motorApp/OmsSrc/drvOms58.cc 9) Raised the precedence of INIT string in motor_init_record_com() for controllers (PI C-848) that require an INIT string primitive before a LOAD_POS can be executed. File modified: motorApp/MotorSrc/motordevCom.cc 10) Numerous fixes for the PI C-848 controller. Files modified: motorApp/PiSrc/[drvPIC848.h,devPIC848.cc,drvPIC848.cc] 11) Two changes were made to the motor record to better support DC motors. First, with this release, if retries are disabled (RTRY=0), then all moves are done in absolute mode. This allows a DC motor user to have the readback values calculated based on either the local encoder (UEIP) or the readback link (URIP), but still have all moves commanded in absolute mode. Previous releases the of the motor record would use relative moves if either the local or external readbacks were enabled, regardless of the state (enable/disable) of the retries. Second, the New Target Monitoring (NTM field) logic is changed to use reference rather than feedback positions. This eliminates unwanted motor record STOP commands at the end of DC motor moves. File modified: motorApp/MotorSrc/motorRecord.cc 12) Motor record bug fix for long moves at backlash velocity after a new target position detected (tdir change). File modified: motorApp/MotorSrc/motorRecord.cc 13) Ron Sluiter added support for the Kohzu SC-800 stepper motor controller. Directory added: motorApp/KohzuSrc 14) Joe Sullivan added support for the piezosystem jena GmbH EDS controller. Directory added: motorApp/PiJenaSrc 15) The examples iocNoMPF and iocWithMPF were renamed iocNoAsyn and iocWithAsyn, respectively. Directories renamed in <motor>/motorExApp and <motor>/iocBoot. Modification Log from R6-1 to R6-2 ================================== 1) Bug fix for Newport PM500 initialization problem. The PM500 driver was not issuing the correct command when it queried for the number of axes at boot up; correct command (XSTAT?), incorrect command (STAT?). This resulted in a "PM500 system error" message on the 1st axis. File modified: NewportSrc/drvPM500.cc 2) A bug was introduced with R6-0. The OMS device support was overwriting PID parameter fields during normalization calculation. File modified: OmsSrc/devOmsCom.cc 3) Bug fix in motor_init_record_com() for logic that determines precedence between controller or save/restore motor position at boot-up. Negative controller positions were not handled correctly. File modified: MotorSrc/motordevCom.cc; take absolute value of position from controller. 4) Added Pete Jemian's motorxU.adl and modifications to the motor.db template that provides the user with the ability to adjust the motor tweak (TWV) and slew velocity (VELO/S) values by a factor of either 0.1 or 10. File added: motorApp/op/adl/motorxU.adl Files modified: - motorApp/Db/motor.db; scalcout records $(P)$(M)_vCh and $(P)$(M)_twCh added. - motorApp/op/adl/topMotors[4/8].adl; added motorxU.adl to menu selection. 5) Clear home request when soft-limit violation occurs. File modified: do_work() in motorRecord.cc 6) Joe Sullivan added support for Thorlabs Piezo Control Module, model MDT695. Directory added: motorApp/ThorLabsSrc 7) Due to releasing R6-1 during Newport development, R6-1 can result in linker errors on the symbol "xpsgathering". Newport users should upgrade to R6-2. Modification Log from R6-0 to R6-1 ================================== 1) MicroMo model MVP 2001 B02 driver; bug fix for recv_mess() always returning nread = 0. File modified: MicroMoSrc/drvMVP2001.cc 2) New Focus models 8750 and 8752; check for special STA cmnd handling. SocketClose() at exit added but disabled pending further testing. File modified: NewFocusSrc/drvPMNC87xx.cc 3) Physik Instrumente (PI) GmbH & Co. C-862; added 17ms "status update delay" to prevent dropped communication characters in controller; i.e. erroneous command error responses. File modified: PiSrc/drvPIC862.cc 4) All motorStatus[xx].adl displays modified to show motor position with text rather than with bar graphs. Files modified: motorApp/op/adl/motorStatus[xx].adl 5) Joe Sullivan added support for the Physik Instrumente (PI) GmbH & Co. model E-710 motor controller. Files added to motorApp/PiSrc: devPIE710.cc, drvPIE710.cc, drvPIE710.h 6) Parker 6K Series; closeSocket() call at EXIT code added (requires asd8 BSP). File modified: drvPC6K.cc Modification Log from R5-9 to R6-0 ================================== 1) The OMS MAXv polling rate, which set is from the MAXvSetup() st.cmd command, is allowed to be as high as the OS clock rate; i.e., (1/epicsThreadSleepQuantum()). File modified: drvMAXv.cc - changed polling rate error check to, 1 <= polling rate <= (1/epicsThreadSleepQuantum()) 2) Since R4-5 (item #9), RDBD must be >= MRES. The test for this condition was done using floating point values. This caused an occasional error that resulted in the record not always issuing a motor move command when RDBD = MRES and the user issued incremental move request equal to MRES. File modified: do_work() in motorRecord.cc - changed test from float to integer math. 3) A warning message was added with R5-6 when a user attempted to move an OMS motor with an invalid velocity (slew <= base). Applications that manipulate the velocity values are unaware of this restriction and create a torrent of these messages. With this release the OMS device will only output this warning message once. File modified: Added message latch to oms_build_trans() in devOmsCom.cc 4) Added a work around for OMS PC68/78 firmware error. PC68/78 controllers make an erroneous response after they are queried with the "?KP" command at boot-up. This resulted in 1st axis having same position (RP command) as last the axis. File modified: Added a dummy comm. transaction to motor_init() in drvOmsPC68.cc. 5) GPIB under ASYN allows only one input EOS character; no output EOS is allowed. Adjustments were made to the Newport ESP300 driver to accomodate this restriction. File modified: Changed EOS from "\r\n" to "\n" in motor_init(). Process the \r in recv_mess(). 6) Mohan Ramanathan and Ron Sluiter added support for the Physik Instrumente (PI) GmbH & Co. Model C-862 motor controller. Files added: Added devPIC862.cc, drvPIC862.cc, PIC862Register.cc and drvPIC862.h to the motorApp/PiSrc directory. 7) Joe Sullivan added support for the ACS Tech80 SPiiPlus motor controller. Files added: Added motorApp/AcsTech80Src directory. 8) Joe Sullivan added support for the Spectra-Physics Encoder Mike Controller (Model: 18011). Files added: Added motorApp/OrielSrc directory. 9) The New Focus Model 8750 Network Controller device support ("PMNC8750") has been changed "PMNC87xx". It now supports both the 8750 and 8752 models. Files modified - All of motorApp/NewFocusSrc. Modification Log from R5-8 to R5-9 ================================== 1) The motor record was ignoring the retry deadband (RDBD) when a new target position was entered and the move was in the "preferred direction"; even when backlash correction was disabled (i.e., BDST == 0). File modified: do_work() in motorRecord.cc 2) Added Kevin Peterson's (UNI-CAT) motorUtil task to the motor record distribution. The motorUtil task monitors and maintains 3 PV's; $(P)alldone, $(P)allstop, $(P)moving. motorUtil is a replacement for the all_com_##.db distributed with the STD support module. See the motorUtil.db file for details. Files added: to <motor>/motorApp/MotorSrc - motorUtil.cc - motorUtilAux.cc to <motor>/motorApp/Db - motorUtil.db Files modified: - <motor>/motorApp/MotorSrc/Makefile - <motor>/motorApp/MotorSrc/motorSupport.dbd - updated examples with motorUtil. 3) Bug fix for the status update field (STUP) not being processed under certain circumstances; e.g., LVIO true, SPMG set to PAUSE, etc.. File modified: motorRecord.cc - moved STUP processing to top of do_work(). 4) Peter Denison (Diamond Light Source) enhanced the Soft Channel device support by eliminating the 50 soft motor limit (MAXMSGS) and replacing it with an unlimited linked list. Files modified: - <motor>/motorApp/SoftMotorSrc/devSoft.h - <motor>/motorApp/SoftMotorSrc/devSoftAux.cc 5) Peter Denison (Diamond), Nick Rees (Diamond) and Mark Rivers (APS) have added a new motor record device support architecture based on ASYN; called "asyn motor" support. The asyn motor support "is an attempt to define a clean, extensible API for motor controller drivers to support". This is a preliminary release of work in progress. Do not use "asynMotor" device support at this time, except for development and testing purposes only. Directory added - MotorSimSrc; motor simulation software. Files added - <motor>/motorApp/MotorSrc/devMotorAsyn.c - <motor>/motorApp/MotorSrc/drvMotorAsyn.c - <motor>/motorApp/MotorSrc/drvMotorAsyn.h - <motor>/motorApp/MotorSrc/paramLib.c - <motor>/motorApp/MotorSrc/paramLib.h Files modified - <motor>/motorApp/MotorSrc/motorSupport.dbd 6) Joe Sullivan added support for the New Focus Model 8750 Network Controller. Directory added - NewFocusSrc. 7) Joe Sullivan added support for the Physik Instrumente (PI) GmbH & Co. Model E-662 piezo controller. Files added - <motor>/motorApp/PiSrc/PIC662Register.cc - <motor>/motorApp/PiSrc/devPIC662.cc - <motor>/motorApp/PiSrc/drvPIC662.cc - <motor>/motorApp/PiSrc/drvPIC662.h 8) Mark Rivers added asyn motor support for the Newport XPS-C8 motor controller. This is a preliminary release of work in progress. However, it has fewer problems than the previous XPS support, so we recommend using the new asyn support for the XPS, with the understanding that it is still under development. Files added - <motor>/motorApp/NewportSrc/XPS_C8_drivers.cpp - <motor>/motorApp/NewportSrc/XPS_C8_drivers.h - <motor>/motorApp/NewportSrc/Socket.h - <motor>/motorApp/NewportSrc/drvXPSAsyn.h - <motor>/motorApp/NewportSrc/drvXPSAsyn.c 9) Mark Rivers added the Trajectory Scanning software for both the Newport MM4005 and XPS-C8 motor controllers to the motor record distribution. Files added - <motor>/motorApp/NewportSrc/MM4005_trajectoryScan.st - <motor>/motorApp/NewportSrc/XPS_trajectoryScan.st - <motor>/motorApp/Db/MM4005_trajectoryScan.db - <motor>/motorApp/Db/XPS_trajectoryScan.db 10) Brian Tieman and Ron Sluiter added support for the standalone, RS-232 versions of the OMS PC68 and PC78 model controllers. The same device (OMS PC68/78) and driver (drvOmsPC68) support both models. Files added - <motor>/motorApp/OmsSrc/devOmsPC68.cc - <motor>/motorApp/OmsSrc/drvOmsPC68.cc - <motor>/motorApp/OmsSrc/drvOmsPC68.h Files modified - <motor>/motorApp/OmsSrc/devOms.dd Modification Log from R5-7 to R5-8 ================================== 1) Mark Rivers added support for the Faulhaber MCDC2805 servo controller. Files added: the <motor>/motorApp/FaulhaberSrc directory and it's contents were added. 2) Mark Rivers added support for building the motor record distribution from a win32-x86 host; i.e., MS Visual C++ compiler. Since the strtok_r() function does not exist on Windows, all calls to strtok_r() have been replaced with calls to epicsStrtok_r(). Numerous files were modified by adding the "epicsShareFunc" declaration to global functions. The epicsStrtok_r() appears in EPICS base beginning with R3.14.8. Hence, the Mclennan and Newport porting of the motor record distribution are dependent on R3.14.8 and above. Files added: - RELEASE.win32-x86 in <motor>/configure. - st.cmd.win32 in <motor>/iocBoot/iocWithMPF. Files modified: for epicsStrtok_r(); - <motor>/motorApp/MclennanSrc/drvPM304.cc - <motor>/motorApp/NewportSrc/drvMM3000.cc - <motor>/motorApp/NewportSrc/drvMM4000.cc 3) Joe Sullivan added support for Parker Hannifin, Compumotor Division, 6K Series controllers. Files added: the <motor>/motorApp/PC6KSrc directory and it's contents were added. 4) Malcolm Walters (Diamond) contributed bug fixes to motorRecord.cc for; - get_units() returned wrong units for VMAX. - get_graphic_double() and get_control_double() returned incorrect values for VELO. 5) <motor>/motorApp/Makefile was modified to build everything by default. This makes integration into synApps easier. Users can comment out particular directories if they do not want them built. File modified: <motor>/motorApp/Makefile Modification Log from R5-6 to R5-7 ================================== 1) ASYN R4-3 compatibility change to nbytesTransfered argument of pasynOctetSyncIO read and write members. Files modified: All drivers using ASYN. 2) IMS MDrive bug fix for not setting acceleration = deceleration correctly. File modified: devMDrive.c 3) Bug fix for homing and jog request not cleared after a limit switch error. File modified: motorRecord.cc - Added clear_buttons() function. - db_post_events home and jog buttons. 4) A delay was added to the driver support with R3-5 to prevent motor controller status updates from reading "stale data". This problem arose under the following scenario; - Start a motor move which is in the opposite direction from the previous move. - Immediately (e.g., < 1ms) ask the controller for status information that includes the motor's direction. - For OMS controllers the required delay is 10ms. Intermittently, the status information returned from the OMS controller would indicate that the direction had not changed; hence the term "stale data". This problem was fixed by inserting a delay between the start of motor motion and the first status update. Unfortunately, the delay was implemented in such a way as to have an undesirable side effect for VME based controllers (i.e., OMS) that interrupt on motion complete. Namely, if the motor move time was less than approximately two VxWorks system clock ticks (33.33 ms for a 60HZ system clock), than the response time to the controller signally motion complete was based on the polling rate, rather than the done interrupt latency. This problem has been fixed by having query_axis() in motordrvCom.c return the remaining delay time to motor_task(), so that motor_task() can delay for the remainder of the delay rather than the larger polling rate. In order to avoid having all device drivers delay for the maximum stale data delay time, each device driver now passes the stale data delay time in the "thread_args" structure at "motor_task" thread creation. Files modified: - numerous changes to motordrvCom.cc - "update_delay" added to thread_args in motordrvCom.h. - "targs" modified in all drivers with "update_delay" initialization. 5) With this release, if the absolute values of both the save/restore's target position and the controller's commanded position are greater than the re-try deadband (RDBD) at boot-up, then DVAL will be initialized from the controller's value. In other words, if the absolute value of the controller's commanded position is greater than the re-try deadband at boot-up, than the controller's position takes precedence over the save/restore value. - Modified motor_init_record_com() in motordevCom.c so that a "Load Pos" command is issued only if, |controller's commanded position| > RDBD. 6) Bug fix for DMOV going true before last readback update when LS error occurs. File modified: process() in motorRecord.cc restores DMOV to false and UNMARK's it so it is not posted until after the last readback update. 7) A bug was introduced with R5-1 item #2 below. This bug resulted in the STOP field not functioning after a target position change. For example, if the user tweaked (TWF) the target position while the motor was moving, activating the STOP field would not stop motor motion the first time; a second STOP field activation would work. File modified: process() in motorRecord.cc. Before calling postProcess(), if the target position has changed and MIP is not MIP_STOP or MIP_JOG_STOP, then set MIP to MIP_DONE and let do_work() process the new target position. 8) In order to avoid device level "Overriding invalid acceleration" warning messages, record support does not send SET_ACCEL commands when acceleration = 0. File modified: postProcess() and do_work() in motorRecord.cc. 9) Avoid STUP errors from devices that do not have a "GET_INFO" command (i.e., Soft Channel). File modified: do_work in motorRecord.cc. If WRITE_MSG(GET_INFO, NULL) returns an error, set STUP to motorSTUP_OFF. 10) Added debug messages to Soft Channel device support and fixed error when devSoft.cc was compiled with "gcc version 3.4.2 20041017 (Red Hat 3.4.2-6.fc3)". File modified: devSoft.cc 11) Kurt Goetze added support for the Physik Instrumente (PI) model C-630 motion controller. Files added: to PiSrc directory; drvPIC630.h, devPIC630.cc, drvPIC630.cc 12) Bug fix for PI C-844 driver processing of axis #4. File modified: drvPIC844.cc, missing break"'s in axis #4 switch/case stmts. in set_status(). 13) Added support for the Physik Instrumente (PI) GmbH & Co. C-848 motor controller. Files added: - devPIC848.cc, drvPIC848.h, drvPIC848.cc 14) A bug was reported by David Maden that occurred when a motor was jogged into a limit switch with the DIR field set to "Neg". Under these conditions, the motor record was not processing the limit error condition correctly. This resulted in the motor record not setting either of the limit error indicator fields (HLS/LLS) and becoming stuck in the "Moving" state. File modified: do_work() in motorRecord.cc; complement CDIR when jogging if DIR="Neg". 15) Added maximum communication timeout for all devices drivers (MAX_TIMEOUT). This value is set in motordrvCom.h to 5 seconds. This helps prevent the "dev_NoInit (init_record_com: callback2 timeout" error message at motor record initialization. Files modified: - Added MAX_TIMEOUT to motordrvCom.h. - Reference MAX_TIMEOUT in motor_init_record_com() in motordevCom.cc. Modification Log from R5-5 to R5-6 ================================== 1) IMS MDrive modifications; 1) Support flexible configuration of limit switches (see <motor>/motorApp/ImsSrc/README file). 2) User must configure MDrives' Echo Mode Flag to two (EM=2). Files modified: drvIM483.h and drvMDrive.cc 2) Removed code from record level code that rounded-up absolute and relative positions before passing them on the device level code. Any rounding required for controllers that communicate in integer values (motor steps) must be done at the device level. File modified: do_work() in motorRecord.cc 3) Modifications made to OMS device drivers that allow omsLib to be built, but not ran, for solaris and linux targets. Files modified: in motorApp/OmsSrc; Makefile, devOmsCom.cc, drvMAXv.cc, drvOms.cc and drvOms58.cc 4) Override invalid acceleration rates and output an error message for OMS devices only. File modified: devOmsCom.cc 5) Replaced hardcoded task/thread stack size and priority values with generic OSI values in all epicsThreadCreate() calls. Files modified: All drivers. 6) Removed the MPF based directory <motor>/motorExApp/ipServerApp from the distribution. Files modified: Removed ipServerApp from <motor>/motorExApp/Makefile Modification Log from R5-4 to R5-5 ================================== 1) Removed the <motor>/motorExApp/Db directory. R3.13.x versions of the motor distribution needed some way to convert *.substitutions files into *.db files, because it could not rely on the synApps version of dbLoadTemplates(). This is not required with R3.14.x since "motor" is able to use the EPICS base version of dbLoadTemplates(). This, in turn, means that all the *.substitutions have been moved to their respective iocBoot directories and loaded directly by dbLoadTemplates(). 2) The motor record would get into an invalid state when it attempted to perform a backlash correction move in the direction of an activated limit switch. File modified: - update CDIR in postProcess() in motorRecord.cc 3) Ported all affected device drivers to R4-1 of asyn. Files modified - all serial and/or GPIB based drivers. 4) Slew acceleration calculations were incorrect. Instead of the correct calculation; A = (Vf - Vo) / t, the record was using A = Vf / t, which is correct only if Vo (VBAS) is zero. Thanks to Harvey Rarback for pointing out this long standing error. File modified - motorRecord.cc 5) Modifications for EPICS R3.14.7 compatibility. Files modified - devSoftAux.cc; changes to epicsThread.h required adding an explicit "#include <stdlib.h>". 6) Modifications for MicroSoft Visual C compiler compatibility. Changed all occurrences of epicsExportAddress(); to extern "C" {epicsExportAddress();}. Files modified - most all. 7) Eliminated calls to devConnectInterrupt() due to C++ problems with devLib.h; i.e. "sorry, not implemented: `tree_list' not supported..." compiler error message. Files modified - drvOms.cc, drvOms58.cc and drvMAXv.cc 8) Omitted iocshRegister() call to resister PIC844Config(). Files modified - PiRegister.cc 9) Added MM4006 to the list of controllers supported by the Newport MM4000 device driver. Files modified - drvMM4000.cc Modification Log from R5-3 to R5-4 ================================== 1) Mark Rivers and I converted the motor record device drivers from MPF to ASYN. Files modified: too numerous to list. 2) OMS MAXv device support was added. Files added: to the motorApp/OmsSrc directory; drvMAXv.h, devMAXv.cc and drvMAXv.cc. 3) In order to support the maximum number of motors per board for the Delta Tau PMAC motor controller (32), several changes have been made to all driver level code. - The "maximum number of axis per board" definition in motor.h (MAX_AXIS) was increased from 10 to 32. - The "driver_table" structure in motordrvCom.h was modified by changing the "axis_names" member from a "char *" to a "char **". The third argument of the sendmsg() declaration was changed from a "char" to a "char *". - The "axis name" argument of sendmsg() was changed from a "char" to a "char *" in all drivers. Those drivers that used the axis name argument of send_mess() were modified accordingly. - Those device drivers that defined an array of axis names in the driver (e.g., MAXv, PIC844) where redefined from an array of char's to an array of strings. Files modified: too numerous to list. 4) If the motor record is processed and there are no functions to perform (i.e., no current or outstanding move request) then the motor record will perform a status update using the STUP field. File modified: do_work() in motorRecord.cc determines that the record is not being processed as a result of a call back and that there is nothing to do. 5) Delta Tau PMAC device support was added. Files added: added the motorApp/DeltaTauSrc directory. Modification Log from R5-2 to R5-3 ================================== 1) The update (polling) rate for the "OMS VME8/44" device driver was incorrect. File modified: - omsSetup() in drvOms.cc. 2) When TWV is set to less than MRES, the following scenario would result. First, tweak forward (TWF). Since DIFF < MRES, the motor is not moved. Next, tweak reverse (TWR). Next TWF again. The motor record does not respond; i.e., DVAL and RVAL are not updated; VAL is not posted. A single tweak, back and forth, confirms that the motor record is not responding. The problem was that do_work() in motorRecord.c was performing the "no move" test before testing for new positions and posting new positions. File modified: - do_work() in motorRecord.cc 3) The motor record would lock-up when a user tried to move off an activated limit switch with the OMS VME58 servo motor controller board (i.e., model -8S). See above "Known Problems" item #3. File modified: - set_status() in drvOms58.cc; had to force CDIR to match the limit switch polarity for record level code to see the limit switch error condition. 4) Added the STUP field (Status Update) to the motor record that allows continuous status updates. The STUP field functions as follows; - the valid values for STUP are OFF(0), ON(1) and BUSY(2). - a Channel Access (CA) client writes ON(1) to the STUP field which causes the motor record to set STUP to BUSY(2) and request a single controller status update. After the status is updated the record sets STUP to OFF(0). - CA client are restricted to writing ON(1) to STUP only when STUP is OFF(0). - it is the responsibility of the user to restrict the frequency (and thus the incurred overhead) at which the CA client writes ON(1) to STUP. With the STUP field it is possible to have another EPICS record whose SCAN field (e.g., Calcout record) is set to periodically scan. This record could periodically write ON(1) to the motor record's STUP field. This would result in continuous, periodic status updates. Under certain circumstances, item #2 under "Known Problems" will occur with the use of STUP. This will be fixed in a later release. Files modified: - MotorSrc/motorRecord.dbd - MotorSrc/motorRecord.cc 5) Eliminated the erroneous "Motor motion timeout ERROR" that would occur if the user repeats 10 consecutive commands that include a controller update command (i.e., INFO) without any intervening motor moves. Modified all drivers to suspend incrementing the "no_motion_count" when the motor is not moving. Files modified: - set_status() in all drivers. 6) PID parameters (i.e., PCOF, ICOF and DCOF fields) were not initialized at boot-up. With this release, if the GAIN_SUPPORT bit in the MSTA is true, each nonzero, PID parameter will be initialized. For backwards compatibility, zero valued PID parameters will not be initialized. File modified: motor_init_record_com() in motordevCom.cc 7) A bug was introduced when item #2, under R5.1 was fixed. This error occurred when the SET/USE field was in the SET mode and the FOFF field was in the FROZEN mode. Under these conditions, if the user entered a new RVAL, the record ignored every other new RVAL; with every other new DVAL that the user entered, RVAL was not updated. VAL always worked. File modified: - load_pos() in motorRecord.c modified so that LVAL is updated when FOFF is in the FROZEN mode. 8) Item#5 under R5-2 was not fixed. There was still a problem in the logic that enforced a time delay between UNDEFINED or IMMEDIATE type commands. On OMS VME58 controllers an INFO update after a LOAD_POS command would, intermittently, yield the previous position. File modified: process_messages() in motordrvCom.cc modified so that a valid "delay" in process_messages() is limited to, 0 <= delay <= (quantum * 2). 9) Previous releases of the motor record forced the sign of ERES to match the sign of MRES. With this release, ERES and MRES may have different signs. This allows the user to change the sign of ERES rather than reverse encoder wires when the motor and encoder direction are reversed. Warning! This does not work with controllers that are doing closed-loop control; e.g., DC motors. Reference (D/A) and feedback (encoder) signals must have the same polarity for DC motors or the motor will literally run away. File modified: do_work() in motorRecord.cc 10) Previous releases of the IMS MDrive device driver did not work. Thanks to Kevin M. Peterson (UNI-CAT) for identifying and fixing the errors in previous releases. A README file has been added to the ImsSrc directory that documents how the MDrive must be initialized before using it with this device driver. Files modified: - Added README file. - drvMDrive.cc; incorporated Kevin's modifications. - devMDrive.cc; Added encoder support. 11) The following three device drivers have been ported from the R3.13.x compatible version of the motor record: - the Physik Instrumente (PI) GmbH & Co. C-844 motor controller. - Kevin Peterson's support for the MicroMo MVP 2001 B02 controller. - Kurt Goetze's support for the Micos MoCo dc controller. Modification Log from R5-1 to R5-2 ================================== 1) Communication with the Newport MM3000 motor controller was getting out of synchronization whenever the MM3000 responded with an error message. This problem was resolved by having recv_mess() in drvMM3000.c detect an error message response, print the error message and then, recursively, call itself. This restored communication transmit/receive synchronization. File modified: - recv_mess() in drvMM3000.cc 2) Spurious interrupts were occurring with OMS VX2-006 ver 1.04 controller boards. For the sake of throughput, the OMS VME8/44 device driver enables the done (DON_E) and input buffer full (IBF_E) interrupts, but disables the transmit buffer empty (TBE_E). The OMS boards are RORA VME type interrupters. The "release" register is the status register. It contains information on the status of the transmit/receive buffer interrupts and the done interrupt. Since the device driver was not using the transmit buffer empty interrupt, it was polling the status register when sending a command to the controller. With the VX2, if the IRQ became active during a status register read cycle, the IRQ was negated at the end of the cycle and the CPU board generated a spurious interrupt. The VME8/44 models somehow prevented the spurious interrupts from occurring by latching the IRQ, if and when, the IRQ became active during a status register read. This problem has been fixed by using all of the OMS board interrupts (i.e., enable transmit buffer empty). The OMS VME8/44/VX2/VS4 design is limited with regard to interrupts by an all or none choice. In addition, the following modifications were made to the OMS8/44 device driver; - Moved the OMS specific data structure "irqdatastr" from motordrvCom.h to drvOms.h. - Changed recv_rng and send_rng in irqdatastr from C to C++ interface. - Added epicsThreadSleep() calls to omsGet() and omsPut() in drvOms.cc during delays. Files modified: - OmsSrc/drvOms.h; enable TBE_E interrupt. - OmsSrc/drvOms.cc; support TBE_E interrupt. - MotorSrc/motordrvCom.h 3) With release R4-7, there was a slight (undocumented) modification made to the way that backlash correction functioned. If a move is in the preferred direction and the backlash speed and acceleration are the same as the slew speed and acceleration, then the backlash move is skipped and the motor moves directly to the target position. Unfortunately, there was a bug in the logic that appeared only when MRES < 0. When MRES < 0, and the backlash speed and acceleration were the same as the slew speed and acceleration, the motor record did the opposite of the requirements; i.e., it did backlash correction when the move was in the preferred direction and did not do backlash correction when the move was not in the preferred direction. File modified: - do_work() in motorRecord.cc 4) The Newport ESP300 would randomly crash at boot-up because an internal parameter ("drive_resolution") was not always, under all configurations, initialized. With this release, the "drive_resolution" is set based on the response to the ESP300 "SU?" command. In addition, the user is required to set MRES to the resolution of the controller as explained in the new document <motor>/motorApp/NewportSrc/README. Files modified: - NewportSrc/devESP300.c - NewportSrc/drvESP300.c File added: - NewportSrc/README (notes on serial communication and ESP300 configuration). 5) There were two timing related bugs with the previous release (R5.1). First, the update rate was not working properly. The end result was that the motor task was polling controllers as fast as possible. Second, there was an error in the motor_task function process_messages() that enforces a time delay between UNDEFINED or IMMEDIATE type commands (e.g., LOAD_POS, SET_ENC_RATIO, etc.) and an INFO type command. One result of this error was that on OMS VME58 controllers an INFO update after a LOAD_POS command would, intermittently, yield the previous position. File modified: motor_task() and process_messages() in motordrvCom.cc 6) Backlash correction after jogging was not working for controllers that do not support multiple position commands on the same command line (e.g., Newport ESP300). This has been corrected with this release with one caveat; in contrast to the feature described in item#3 above, backlash correction is always done after jogging, regardless of the jog acceleration and speed parameters. File modified: Added extra jog backlash states to postProcess() in motorRecord.cc 7) Although there is no explicit statement in the motor record documentation, most user's would expect the "Readback settle time" field (DLY) to update the readback after the delay timeout. It did not do this. With this release, the readback is updated one time after the timeout. Since a functioning DLY field performs the same function as the drv<driver>ReadbackDelay variables, with the added advantage that the delay can be motor specific, the drv<driver>ReadbackDelay variables have been deleted (except for the MM4000). File modified: - callbackFunc() and process() in motorRecord.cc Modification Log from R4-5 to R5-1 ================================== 1) The following scenario would put the motor record into an invalid state. A new target position (i.e., VAL/DVAL/RVAL) is written to the motor record under the following conditions, - motion is in progress (i.e., DMOV is false). - the new target position is different from the actual position by less than the retry deadband (|DIFF| < RDBD). - backlash correction is enabled (i.e., BDST is non-zero) and the new move is NOT in the "preferred direction" (preferred direction is the direction in which the motor moves during the backlash-takeout part of a motor move). File modified: do_work() in motorRecord.cc. Update last target positions and set DMOV TRUE, only if the motion in progress indicator (MIP) is DONE. 2) A bug was introduced in R4-5 when backlash correction was changed per item #11 below. The error occurred when a new target position was issued while the motor was moving. The motor would move to the new target position at the backlash velocity rather than the slew velocity. This bug was discovered by Kevin M. Peterson. File modified: process() in motorRecord.cc. Before calling postProcess() check if the target position has changed. 3) A conflict between the requirements specified in item #2 below and the goal of having the same record level functionality for all device drivers, including Soft Channel device support, was found by Tim Graber. A problem occurred with, for example, the SoftMotorEx.db that is distributed with the motor record, when backlash was enabled in the "hard" motor. The result was that the "soft" motor would interpret the "hard" motor's backlash correction as the motor going in the wrong direction, and stop the "hard" motor from completing the backlash correction. With this release, the requirements on how the motor record processes a new target position while the motor is in motion have been modified based on a new field; New Target Monitor (NTM). Case #1: The motor record is given a new position, which is in the opposite direction from the current motor motion. If NTM is YES, the motor is immediately stopped and given a motion command to the new position. If NTM is NO, the motor completes the previous move before it is given a motion command to the new position. Case #2: The motor record is given a new position, which is in the same direction as the current motor motion, but the new position is closer to the motor's current position than the original target position. If NTM is YES, the motor is stopped after it has gone past the new position; then a command is given to return to the new position. If NTM is NO, the motor completes the previous move before it is given a motion command to the new position. Case #3: The motor record is given a new position, which is in the same direction as the current motor motion, but the new position is further from the motor's current position than the original position. After the motor reaches the original target position and stops, a command is given to the new target position. This case is independent of NTM. Files modified: - NTM field added to motorRecord.dbd - process() in motorRecord.cc checks NTM field before sending stop motor command. 4) A Soft Channel device support design limitation was discovered by Tim Mooney. The problem is a result of the modifications made with R4-5, item #5 below, where the "soft" motor synchronizes it's target position (i.e., VAL/DVAL/RVAL) with it's readback/raw position (RBV/DRBV/RRBV). Given an application where there are two or more "soft" motors driving the system (e.g., slit), when one soft motor is moved, the other soft motor "sees" it's readback changing and synchronizes it's target position with it's readback position at the end of the move, thereby losing it's target position. With this release, the LOCK field has been added to prevent synchronization due to the readback changing. Files modified: - LOCK field added to motorRecord.dbd - soft_dinp_func() in devSoft.cc checks LOCK field before putting dinp_value into HARDMOVE state. 5) Device driver support added for the Newport ESP300 motor controller. Files added: - NewportSrc/devESP300.cc - NewportSrc/drvESP300.cc 6) An uninitialized pointer error check was omitted from a Newport ESP300 device function. This resulted in a bus error at boot-up if the IOC failed to connect to the ESP300 controller. File modified: ESP300_init_record() in the devESP300.cc 7) "device directive" support has been extended to the PREM and POST fields for OMS devices only. The new device directive supports changing the value of a database variable. The syntax is as follows: PREM - @PUT(<pvname>, <pv-value>, <delay in seconds>)@ POST - @PUT(<pvname>, <pv-value>)@ Note that the PREM supports a delay argument, but that POST does not. The "Readback settle time" field (DLY) should be used to create a time delay after the PV specified in the POST field is written. See the "Miscellaneous fields" in motorRecord.html for further information on the INIT, PREM and POST fields. Files modified: devOmsCom.cc, drvOms58.cc and drvOms.cc 8) Device driver support added for the Intelligent Motion Systems (IMS) MDrive17 model motor controller. Files modified: - [dev/drv]MDrive.cd added to ImsSrc/Makefile.Vx - "MDrive" device and driver added to devImsMotor.dbd Files added: - [dev/drv]MDrive.cd added to ImsSrc directory. 9) Eliminated redundant DMOV monitor posting's. For example, with previous releases the motor record would post DMOV=0 twice if backlash correction was enabled and the user jogged the motor. Files modified: modified postProcess(), process() and load_pos() in motorRecord.cc. 10) A Home Velocity field (HVEL) was added. Files modified: - HVEL added to motorRecord.dbd - motorRecord.cc - op/adl/motorx_setup.adl 11) There is a problem with OMS VME58 ver 2.35-8 firmware when used with MVME2700 CPU boards. The problem is that the controller board intermittently, reports that there is no limit switch error when there is an error. This error can occur if the user repeatedly, tries to move in the direction of the limit switch when the limit error condition exits. A delay has been added to work around the problem. File modified: - drvOms58.cc; conditional delay added to query_done(). 12) With release R4-5, DBE_LOG was omitted from the event select mask of all db_post_events() calls. This prevented archival clients from being notified of process variable changes. With this release, DBE_LOG is on for all calls to db_post_events() Files modified: - motorRecord.cc, motordevCom.cc and devSoft.cc 13) Mark Rivers added support for the Mclennan PM600 controller. Files modified: - MclennanSrc/devPM304.cc - MclennanSrc/drvPM304.cc - MclennanSrc/drvPM304.h 14) MX device driver support added. MXmotorSrc directory added. Modification Log from R4-4 to R4-5 ================================== 1) The GPIB and RS232 serial communication error detection and reporting mechanism was unreliable. In addition, once a communication error was detected, the motor task did endless periodic communication retries. With this release, once a communication error is detected, one retry is attempted (Further retries are made, if the position RETRY field is non-zero). If the retry fails, then a communication error is reported. No further attempt is made to communicate with the controller until subsequent user input (e.g., a new target position is entered). This change affects all device drivers using GPIB or RS232 serial communication mechanisms (i.e., non-VME Bus boards). Files modified: motordrvCom.h - added RETRY to CommStatus enumeration. drvMM4000.c, drvMM3000.c, drvPM500.c, drvIM483PL.c, drvIM483SM.c - start_status() allows one retry after a communication error. - set_status() sets RA_PROBLEM along with CNTRL_COMM_ERR to terminate node. 2) The requirements on how the motor record processes a new target position while the motor is in motion have never been specified. The requirements are as follows: Case #1: The motor record is given a new position, which is in the opposite direction from the current motor motion. The motor is immediately stopped and given a motion command to the new position. Case #2: The motor record is given a new position, which is in the same direction as the current motor motion, but the new position is closer to the motor's current position than the original target position. The motor is stopped after it has gone past the new position; then a command is given to return to the new position. Case #3: The motor record is given a new position, which is in the same direction as the current motor motion, but the new position is further from the motor's current position than the original position. After the motor reaches the original target position and stops, a command is given to the new target position. (Previous motor record versions ignored the new target position.) File modified: * process() in motorRecord.c * motorRecord.dbd - the PP field is initially zero. - replaced PDIF with CDIR field. 3) For two CPU board configurations only (i.e., EPICS and IP satellite boards), erroneous timeouts occurred if the EPICS board booted much faster than the satellite board. File modified: CommSrc/serialIOMPF.cc; increased timeout from 2 to 10 seconds in call to msgQReceive() from serialIO(). 4) The "Driver Power Monitoring" feature (available only with OMS VME58 controllers) was erroneously and randomly being enabled. This occurred because the internal state indicator (dpm) was never initialized to OFF at boot-up. File modified: motor_init_record_com() in motordevCom.c. Explicitly initialize "dpm" to OFF. 5) The Soft Channel device support modifications: - Prevent record processing before "interruptAccept" is true. This helps prevent alarms. - If the readback is changing, but motion was not initiated by this record, then reset the motor record's target to actual position (i.e., VAL/DVAL/RVAL = RBV/DRBV/RRBV) after the move. As always, the Soft Channel motor record's DMOV field is guaranteed to execute and post a 1/0/1 pulse, but MOVN remains zero throughout a move that was not initiated by the Soft Channel record. - Lowered the priority of the "soft_motor task below the "dbCaLink" task. This fixes the "DMOV processing before the last DRBV update" problem. Files modified: - devSoft.h, devSoft.c, devAuxSoft.c 6) For VMEbus based motor controllers only (i.e., OMS), a "hole" in an array of VME based motor controller boards caused the system to crash with a memory "access error" on the address of the missing controller. For example, if oms58Setup(3, 8, 0x4000, 190, 5, 10) was issued without a board at 0xFFFF5000, a bus error would occur if the user attempted to move a motor on the missing board. Files modified: drvOms58.c - start_status() was not checking for valid motor_state[card] pointer. drvOms.c,drvOms58.c - "total_cards" changed from total detected to total cards that "memory is allocated for". This allows boards after the "hole" to work. 7) For OMS motor controllers only, if the PREM field was set without a leading space character (e.g., "BH8") this resulted in an invalid OMS command (e.g., "AX VB10 VL1000 AC5000BH1 MA200 GD ID"). File modified: devOmsCom.c - A space character was prefixed to the PREM field in oms_build_trans(). 8) Eliminated support for the "ASCII record separator (IS2) = /x1E". Files modified: - MotorSrc/motordrvCom.c: Removed support for splitting and shuffling concatenated command messages in query_axis(). - ImsSrc/devIM483[SM/PL].c: Moved the calls to motor_[start/end]_trans_com() into IM483[SM/PL]_build_trans(). Don't call motor_end_trans_com() if motor command is a NOOP. 9) With previous releases of the motor record, the RES field was set to either ERES or MRES, based on whether or not the following statement was true; MSTA indicates an encoder is present, AND, UEIP is set to YES. This state (i.e., MSTA indicates an encoder is present, AND, UEIP is set to YES) resulted in the record converting all position and velocity related values from EGU's to raw encoder counts before sending them to the motor controller. This is the manner in which the OMS controllers work (see OMS User's Manual, ER# command). With this release, all raw positions, velocity and acceleration are in terms of motor steps. - RES always equal to MRES. RES preserved for backward compatibility only. All instances of RES have been replaced with MRES. Files modified: - MotorSrc/motor.h - MotorSrc/motorRecord.c - MotorSrc/motordevCom.c - OmsSrc/devOmsCom.c - NewportSrc/devMM3000.c - NewportSrc/devMM4000.c - NewportSrc/devPM500.c - ImsSrc/devIM483PL.c - ImsSrc/devIM483SM.c - V544Src/devV544.c 10) Jog velocity was not checked for validity when VMAX or VBAS was changed. Files modified: MotorSrc/motorRecord.c, added JVEL error check in special(). 11) Previous motor record releases put both the "slew" and backlash correction moves on the same motor controller command line. Some controllers (i.e., OMS) handled this correctly by processing the slew move followed by the backlash correction move. Other controllers (i.e, Newport) did not handle this correctly and processed the commands immediately, resulting in the controller moving to the target position without backlash correction, but at the backlash correction velocity. With this release, backlash correction commands are not issued to the controller until after the slew move is completed. File modified: MotorSrc/motorRecord.c - Moved the backlash commands from do_work() to postProcess(). - Added a MIP_MOVE_BL state indicator. - Eliminated redundant MARK(M_MIP)'s. - Combined MIP_MOVE with MIP_JOG_STOP logic in postProcess(). 12) Mark Rivers has added device driver support for the following motor controllers: - Advanced Control Systems, Corp. model MCB-4B. - Mclennan model PM304. 13) motor_callback() in motordevCom.c calls dbProcess(), rather than calling motor record process() directly. This supports standard database processing functions like TPRO and breakpoints. 14) Update <motor>/config files to synApps R4.4 and epics base 3.13.5: Files modified: RULES.Db - added "depends::" makeConfigAppInclude.pl - updated to synApps R4.4 version. makeIocCdCommands.pl - updated to synApps R4.4 version 15) Some databases where converted to VDCT; i.e., motor.db, SoftMotorEx.db. 16) Added separate +/- limit switch status bits in the MSTA field. There are two types of motor controllers. The first type provides a limit switch error and a direction indicator, the second type provides the state of both limit switches, but no direction indicator. In the first case, the device driver knows that an error has occurred, that motion has stopped, and that based on the direction indicator, which limit switch was activated. In the second case the device driver must determine, based on the limit switch states and an internally generated direction indicator, whether or not a limit switch error has occurred. The OMS controllers are an example of the first type of controller and the IM483 is an example of the second type of controller. Files modified: - MotorSrc/motor.h - MotorSrc/motorRecord.c - MotorSrc/motordrvCom.c - All drivers; i.e., */drv*.c 17) Post all fields when recGblResetAlarms() returns an alarm. Modification Log from R4-3 to R4-4 ================================== 1) config/RELEASE: - Changed comments to indicate that MPF_SERIAL must be defined if either serial or GPIB communication is required. - Updated support modules to latest releases; mpfSerial R1-2, MPF R1-6, EPICS base R3-13-4. 2) Examples: - iocBoot/iocNoMPF/st.cmd; added GDCT compatible Soft Channel device driver example. - iocBoot/iocWithMPF/[st.cmd and st_mpfserver.cmd]; for 1 CPU configuration, both initGpibGsTi9914() and HiDEOSGpibLinkConfig() must have the same GPIB server name. - motorExApp/Db/[SoftMotorEx.db andSoftMotorEx] ; added a GDCT compatible Soft channel device driver database example. 3) Jog Velocity and Acceleration. Two new fields (JVEL and JAR) were added to support jog velocity and acceleration parameters. Only the OMS and IMS device drivers support changing the Jog Velocity while jogging. Files modified: motorRecord.dbd - Jog specific fields (JVEL and JAR). motorRecord.c - Process JVEL in special(). devIM483[PL/SM].c, devMM[3/4]000.c, devPM500.c, - Added Jog Velocity motor command. devOmsCom.c - Added clear axis done flag command (CA) to home and jog commands. This is needed so that JVEL does not see done from previous command. 4) Travel limits can be disabled by setting both the dial high and low limits equal to zero; i.e., DHLM = DLLM = 0. File modified: motorRecord.c 5) A problem was discovered with entering target positions through RVAL. If the difference between the current and the next target position (i.e., RDIF, DIFF) was less than the retry deadband (RDBD), and the next target position was in the "preferred direction", then the new RVAL was ignored. File modified: motorRecord.c - Root cause in do_work() was that under the above conditions, LVAL was not updated. 6) The following scenario would put the motor record into an invalid state. First, start the motor moving by giving it a new target position. Next, while the motor is still moving, enter a new target position that is beyond the software travel limit (HLM/LLM) . The invalid target position is rejected (as it should be), but when the first target position is reached the MIP field is left in the MOVE state, rather than the DONE state. File modified: motorRecord.c - Modified do_work() LVIO logic to set DMOV true only if MIP is DONE. 7) Removed Hideos file motorApp/CommSrc/serialIO.cc from distribution. 8) The following scenario would put the motor record into an invalid state. At the end of a move a "retry" is requested. The MIP field is set to RETRY in maybeRetry(), but before the retry request can be processed in do_work() the STOP field is set TRUE. This results in a STOP command being issued, but no subsequent processing callbacks, which leaves the record's MIP in the STOP state and DMOV false. File modified: motorRecord.c - Modified do_work() STOP and SPMG processing to set MIP <- DONE and DMOV <- TRUE when MIP == RETRY. 9) As suggested by Brian McAllister, type specifications for all bit-fields found within unions have been changed to "int". This modification elminates the ANSI warning messages and has no effect on the machine code generated. Files modified: motorRecord.c - mmap_field and nmap_field unions. drvOms58.h - all control/status registers. Modification Log from R4-2 to R4-3 ================================== 1) An error was introduced into the motor record when item #14 under R4-2 was implemented. This error occurred if the STOP field was activated when the motor was not moving (i.e., MIP = 0). The motor record would become "stuck", and not respond to a move request (due to the internal state machine associated with MIP being set to the "stop" state), until the condition was cleared by either a SPMG-stop or some other user action that forced the MIP field to zero. File modified: motorRecord.c - Changed logic in do_work() so that the stop command is always sent to the controller when the STOP field is activated; but, the MIP field in only set to the "stop" state if the current state is not STOP or DONE. 2) Due to ambiguous and conflicting Newport PM500 documentation, the velocity and acceleration values for the PM500 controller were off by a factor of 1,000. File modified: devPM500.c - Scaled velocity, acceleration and jogging command parameters by 1,000. 3) HIDEOS is no longer supported. Files modified: config/RELEASE - Removed HIDEOS path. motorApp/CommSrc/Makefile.Vx - Removed HIDEOS. 4) Added Mark Rivers soft channel modifications as a conditional compilation option (i.e., DMR_SOFTMOTOR_MODS). Files modified: motorApp/MotorSrc/Makefile.Vx motorApp/MotorSrc/motorRecord.c motorApp/SoftMotorSrc/Makefile.Vx motorApp/SoftMotorSrc/devSoft.h motorApp/SoftMotorSrc/devSoft.c 5) The Soft Channel device driver example, softex.db, was removed from motorExApp/Db and replaced with a GDCT compatible copy, SoftMotorEx.db. The corresponding GDCT data file is SoftMotorEx. Modification Log from R4-1 to R4-2 ================================== 1) The following requirement was lost with release V4.0. At boot-up, if one field of a field pair (i.e., VMAX/SMAX, VBAS/SBAS, VELO/S, BVEL/SBAK) is zero and the other field is nonzero, the nonzero field takes precedence. If both fields of a given field pair are nonzero, the RPS member of the field pair (i.e., SMAX, SBAS, S, SBAK) takes precedence. File modified: motorRecord.c - Changed logic in check_speed_and_resolution(). 2) An error was introduced into the Oms device support with V4.0. The 1st argument of the omsSetup(nCards, ...) function in the st.cmd file is for the maximum number of VME8 and/or VME44 cards to be supported in a specific IOC crate. If the "nCards" argument was set to anything other than the actual number of cards in the IOC crate, the "dbior" function would result in erroneous information or a bus error. File modified: drvOms.c - Restored statement in motor_init() that sets motor_state[] to NULL when card not found. 3) An error occurs with the OMS VME58 when the user runs the motor into a limit switch and then attempts to move away from the limit switch. If either an absolute or incremental move is utilized to move away from the limit switch, the OMS VME58 ignores the 1st move attempt. Subsequent moves work. In addition, the user can jog off a limit switch. This error was hidden in most applications if RTRY was nonzero. File modified: devOmsCom.c - Changed logic in oms_build_trans() to prefix MP or MM command to any move when overtravel status indicator is ON. 4) Added support for EPICS GPIB Module Version 0-0 from Benjamin Franksen. Warning! Neither GPIB 0-0 are my usage of it has been throughly tested yet. Files modified: config/RELEASE - Configuration instructions added. CommSrc/Makefile.Vx - Conditional compilation label. CommSrc/gpibIO.c - Conditional compilation for unbundled GPIB module. 5) All motorApp/*/Makefile.Vx files were modified to take advantage of the macro found in Benjamin Franksen's makefiles; i.e., LIBOBJS = $(SRCS.c:../%.c=%.o) 6) Replaced all occurrences of "include <stdioLib.h>" with "include <stdio.h>. Wind River has labeled stdioLib.h as "obsolete vxWorks 5.0 header file". Files modified: drvOms.c, drvOms58.c, devMM3000.c, devMM4000.c, drvMM3000.c, drvMM4000.c 7) Added support for the Newport PM500 motion controller. This device/driver is based on Mark River's PM500 V2.0 release. Files added: devPM500.c and drvPM500.c 8) Removed QUERY from the list of valid "command types". It was unused. Enumerated message types. File modified: motordrvCom.h and motordrvCom.c 9) Some motor controllers (e.g., PM500) unconditionally respond when motor commands are sent. Although these communication responses are not needed (they are in fact a nuisance), they must be received so that later communication transactions are kept in synchronization. To this end, a flag was added to the "controller" structure to indicate where or not the associated motor controller responds to all commands. Files modified: motordrvCom.h - Added "cmnd_response" member to "controller". motordrvCom.c - Get controller response if "cmnd_response" is set ON. drvMM3000.c, drvMM400.c, drvOms.c drvOms58.c - Initialize "cmnd_response". 10) Modifications were made to the following files to adopt Mark River's method of command line termination; i.e., the send_mess() function appends the command line termination character to the string. Files modified: motordrvCom.h motordrvCom.c - Removed command line terminator argument from motor_send() and driver_table member, send(). motordevCom.h - Function declaration changes. motordevCom.c - Removed command line terminator argument from motor_end_trans_com(). 11) Added support for the Intelligent Motion Systems, Inc. IM483 controller. Two device/driver versions are available; IM483PL for "party line" and IM483SM for "single" communication mode. See the IMS "Software Reference manual Revision 051794 for detail. Directory added: motorApp/ImsSrc Files added: drvIM483.h, devImsMotor.dbd devIM483SM.c, drvIM483SM.c devIM483PL.c, drvIM483PL.c Files modified: motorApp/Makefile - Added ImsSrc directory. 12) The record level support assumed that the motor controller would accept two motion commands on the same command line. This occurs when backlash compensation is enabled. Since the IM483[PL/SM] does not have this capability, support for a command line "record separator" character was added. The record separator is defined as an ASCII (IS2) character = /x1E. Currently, only one record separator is allowed in a command line. Files modified: motordrvCom.c - process_messages() searches for a record separator. If found, it splits the message, outputs the 1st part and stores the 2nd part back into the front of the message buffer. - query_axis() detects 2nd part of messages, outputs it and clears the message buffer. 13) For those controllers whose command lines require an alphabetic character for the axis name identifier (e.g. OMS, Oms58, IMS483PL), support has been added for driver specific axis names. An axis name array pointer was added to the driver_table structure. Files modified: motordrvCom.h - Moved mess_card_query member axis_names to driver_table. motordrvCom.c - The global oms_trans_axis[] was removed. motordevCom.h - Removed axis "name" member from axis_stat. motordevCom.c - Removed initial string function argument from motor_start_trans_com(). All drv{driver}.c files were modified to add an axis name array point to their driver_table; (NULL for device/drivers that do not use axis names; e.g., MM3000, MM4000/5). 14) An error was introduced in V4.0 which prevented the record from processing a jog request if the UEIP field was changed. Issuing a STOP or SPMG/STOP, cleared the error. Files modified: motorRecord.c - Activate DMOV when loading a position (i.e., load_pos() called). 15) Removed unused C macros from driver level files. Files modified: - devMM3000.c, 16) Records were stuck with DMOV = 0 if the user requested a move and there was no underlying controller. No error message, besides the "card does not exist" message at boot-up, would appear. With this release, the COMM_ALARM is set and DMOV is reset if the controller does not exist. File modified: - motor_end_trans_com() in motordevCom.c 17) An error was introduced in V4.0 which prevented backlash correction from occurring after a JOG. Files modified: postProcess() in motorRecord.c 18) Divide-by-zero errors were occurring in do_work() of motorRecord.c. File modified: Added various error checks in motorRecord.c against ERES becoming zero 19) Two motion commands were being sent by do_work() if the record was processed twice before a callback was processed. This could occur under various scenarios - banging on the tweak button with a low frequency update rate. - the motor record was (accidentally) processed from a periodic scan with a higher frequency than the update rate. File modified: In motorRecord.c, do_work(), changed the "motor moving" test from the "movn" to the "mip" field. 20) An error was introduced into the motor record with V4.0. This error occurred on the rare occasion when a target position (i.e., VAL or DVAL) fell almost exactly half way between two integer RVAL values, and the retry feature was enabled (i.e., RTRY is nonzero). The motor record would 'hang' under these circumstances with DMOV set FALSE and RCNT set to one. Files modified: motorRecord.dbd - erroneous retries were a result of round-off error. Changed RES from a 'float' to a 'double'. motorRecord.c - Prior to V4.0, do_work() handled retry request to the same position by setting DMOV true and exiting (see code; (npos == rpos)). Broke this logic in V4.0 because of item #13. Fixed, by testing for MIP_RETRY, and clearing MIP. 21) Moved device specific structure "encoder_status" from motordrvCom.h to drvOmsCom.h. Files modified: motordrvCom.h and drvOmsCom.h Modification Log from R4-0 to R4-1 ================================== 1) Three errors in the OMS VME58 driver were found. All the errors caused the same problem. Namely, erroneous retries occurred intermittently when multiple axes were commanded to move on the same controller. This error occurred because old position data was being passed back from the driver after Done was detected. The erroneous intermittent retries occurred more often when the Oms setup parameters called for a high frequency (e.g., 60 Hz) "polling" rate and Oms interrupts were enabled. File modified: drvOms58.c Function modifications: start_status() - Wait forever for control register update bit to clear before setting. set_status() - Request Data Area Update after DONE detected so that both ASCII command data and shared memory data match. motorIsr() - Only write to control register if update bit is off (the ISR was clearing the update bit rather than the VME58 board. 2) Moved the Serial/GPIB communication label definitions from Newport specific drvMMCom.h to the more general motordrvCom.h. New motor controllers will require these labels. Files modified: drvMMCom.h, motordrvCom.h, drvMM4000.c, drvMM3000.c 3) With previous releases, when using the motor record with soft channel device support, the DMOV field would become stuck on if the user put the motor in SET mode and entered a new DVAL or RVAL. With this release, the above user action (i.e., "setting" a soft motor) results in the record being processed; which, in most cases, will clear DMOV. Files modified: devSoft.h, devSoft.c, devSoftAux.c 4) A problem with issuing a stop command (via either the STOP or SPMG field) was found with ALL OMS boards and ALL versions of the OMS device drivers. The root cause of this problem is a statement in the OMS manual that is not entirely correct; i.e., the AC and VL commands are not completely queued. The motor record issues both the target move and the backlash move on the same command line to the motor controller. Each move (target and backlash) has its' own acceleration rate. The problem was that when a STOP command was issued during the target move, the backlash acceleration would go into effect. This could result in a prolonged deceleration if the backlash acceleration rate (BACC) is much smaller than the target acceleration rate (ACCL). With this release both the devOms and the devOms58 device support issue the target acceleration rate (ACCL) with the STOP command. File modified: devOmsCom.c Modification Log from V3-5 to R4-0 ================================== 1) EPICS base 3.13.1 compatibility. - Changed dev{Connect/Disconnect}Interrupt() to dev{Connect/Disconnect}InterruptVME() Files modified: drvOms.c, drvOms58.c 2) Newport MM3000 Device Support. - Renamed drvMM400.h -> drvMMCom.h - Added device and driver support in source code files "devMM3000.c" and "drvMM3000.c". - Modified MM3000_build_trans() in "devMM3000.c" and motor_end_trans_com() in "motordevCom.c" to prevent motor commands from being sent if card does not exists. Bus error occurred with MM3000 device/driver when card did not exists and motion was commanded from medm display. 3) Eliminated the GAIN field and the associated SET_CGAIN command; Files modified: motorRecord.dbd, motor.h, devMM3000.c, devMM4000.c, devOmsCom.c, and motorRecord.c 4) Previous releases of the motor record had a potential problem associated with the homing function. The motorx_all.adl MEDM display set the HOM[F/R] fields on and off. Depending on the pollRate defined in the st.cmd Setup command and the speed at which the user toggled the HOM[F/R] buttons; the record level software would turn off the DMOV field when the HOM[F/R] button was turned off and a motor status update had not yet been received. As a result, when the motor completed it's homing function the command positions (i.e., VAL, DVAL, RVAL) were not updated. All previous motor record releases contained the DMOV problem; the commanded position update problem was limited to the previous release (V3.5). With this release, a dbPutField to either HOMF or HOMR is valid on a FALSE to TRUE transition (i.e., 0 to 1), but a TRUE to FALSE transition (i.e., 1 to 0) will result in an error. - Modified motorRecord.dbd; added HOM[F/R] "special" processing. - Modified motorRecord.c; since OPI can't reset HOM[F/R], postProcess() does it; return error from special() if OPI tries to write to HOM[F/R] when MIP indicates homing active. 5) Previous releases of the motor record allowed the auto restore to take precedence over the controller when initializing the target position (i.e., DVAL). With this release, if both the auto restore and controller target position values are non-zero at boot-up, then DVAL will be initialized from the controller's value. In other words, the controller's target position takes precedence. - Modified motor_init_record_com() in motordevCom.c so that a "Load Pos" command is issued only if the position from the controller is zero. 6) Consolidated common driver local variables in the motordrvComCode.h file. - Created motordrvComCode.h - Moved common local variables from drvOms.c, drvOms58.c, drvMM3000.c, drvMM4000.c 7) Uninitialized Oms/Oms58 Driver Error Check. With previous release, if the Oms or Oms58 driver was some how omitted from the database, a "... card does not exist" error message would result. With this release, an explicit error check and corresponding error message (i.e., "Oms[58] driver uninitialized.") results at record initialization if a required driver is not initialized. (Because of the particulars of MM[3000/4000] initialization, this is not an issue with Newport controllers.) - Added pointer to initialized indicator to driver table structure in motordrvCom.h - Added error checks in oms_init() and oms_end_trans() in both devOms.c and devOms58.c - For drvOms.c, drvOms58.c, drvMM3000.c and drvMM4000.c - initialized pointer to local initialized indicator in driver table. - set initialized indicator ON in init(). 8) Both the MM3000 and MM4000 device driver support could generate a bus error under the following conditions: 1) The user selected GPIB communication mode. 2) At boot-up, the driver could not communicate with the device, resulting in a "... card does not exist!" error. 3) Motor motion is commanded. - Modified MM3000_build_trans() and MM4000_build_trans() in devMM3000.c and devMM4000.c, respectively, to test for NULL board pointer. 9) Eliminated MM3000 and MM4000 device driver "internal" offset. - Removed "offset" from MM3000_build_trans() and MM4000_build_trans() in devMM3000.c and devMM4000.c, respectively. - Read controller's home preset position at boot-up; save and restore save home preset position when "setting" DVAL or RVAL. 10) For MM4000/40005 only, the controller's position resolution (TU controller command) is read and saved so that the device driver can convert between motor record "raw" positions and controller egu's. 11) Modified report() in drvMM4000.c by adding message; "MM4000 controller # connection failed." 12) For the MM3000 when the GPIB communication interface is selected; sometimes the MM3000 returns a NULL communication response. Hence, set_status() in drvMM3000.c was modified to detect a NULL response and resend the status query. 13) A jog request occurring during a jog induced backlash correction would, intermittently, cause the MM4000 to go into an uncontrolled jog; i.e., the user would set JOG[F/R] false, but the jogging would not stop. This occurred because the sequence of events were as follows: <- mip = 0 JOGF=1 -> <- mip = 1; Jog command JOGF=0 -> <- Stop command <- Done <- mip = 4; backlash command JOGF=1 -> <- Done <- mip = 1; Jog command <- mip = 4; backlash command JOGF=0 -> In the above event sequence, since mip=4 when JOGF is set to zero, no stop command is sent. The MM4000 only accepts one motion command at a time. Therefore, the last backlash command is ignored in the above event sequence. The end result is an uncontrolled jog operation. Modifications were made to motorRecord.c to fix this; in general, a finite state machine was strictly enforced on jog request, jogging, stopping a jog and the backlash after jogging. Jog processing is isolated from the JOG[F/R] fields. Specifically, - Added two new state indicators to MIP; MIP_JOG_REQ and MIP_JOG_STOP. The jog states now consist of the following; Start (mip=0), Request, Jogging, Stopping and Backlash. - In postProcess(); - replaced (MIP_JOGF | MIP_JOGR) with (MIP_JOG_STOP) when testing for done stopping after jogging. - replaced (pmr->jogf || pmr->jogr) with MIP_JOG_REQ when testing for done stopping after jog. - "Queued" jog request (stop and jog buttons both on) processing has been moved from postProcess() to do_work(). - Skip backlash operation if backlash distance is zero. - In maybeRetry(); - Clear MIP if Max retry count (RTRY) set to zero. - When clearing MIP, don't clear MIP_JOG_REQ. - In do_work(); - Detect and process "Queued" jog request. - Use MIP state indicators rather than JOG[F/R] fields to process jog function. - Don't want "DVAL has changed..." logic to get processed when doing jog stop or backlash. Detect and do Normal Return. - In special(); Set MIP_JOG_REQ on only if MIP=0 and the corresponding hardware limit switch is not active. 14) Eliminated device dependent code from process_messages() in motordrvCom.c; specifically, removed concatenating a carriage return to end of controller message. The new method is to pass a pointer to the command line terminator string in function arguments; beginning with <device>_end_trans(), through motor_end_trans_com() in motordevCom.c, to the "send()" function specified in the driver table. Files modified: motordevCom.h, motordrvCom.h, devMM3000.c, devMM4000.c, devOms.c, devOms58.c 15) In motordrvCom.h, changed "controller" structure member "MMptr" to "DevicePrivate". Files modified: devMM3000.c, devMM4000.c 16) All files were modified as follows: - standard headers were added. - original headers and modification history's were restored. - all instances of #include <motorRecord.h> have been changed to #include "motorRecord.h". As Mark Rivers explained, 'Include files which are in <> are not included in dependencies by GCC. Thus, if motorRecord.dbd is changed, devMM4000.c will not be recompiled unless the <> are changed to "".' 17) The task name associated with each device driver has been given a unique name; i.e. "<device>_motor". Previously, all the motor tasks were given the same task name, "tmotor". This prevents using some of the Tornado tools (Browser, CrossWind, etc.). Files modified: drvMM3000.c, drvMM4000.c, drvOms.c, drvOms58.c 18) Removed my_strtok() from and replace with VxWorks library function strtok_r(). Files modified: drvMM3000.c, drvMM4000.c, drvOms.c, drvOms58.c 19) Added record report function for Oms driver. File modified: drvOms.c 20) Added maximum allowable velocity fields; VMAX and SMAX. - VMAX/SMAX added to motorRecord.dbd with Access Security Limit = 0. - changed the Access Security Level for MRES, UREV, VBAS and SBAS from one to zero. - see motorRecord.html for valid velocity range limits. - optimized calls to fabs(pmr->urev). - added range_check() for validity checking bounded fields. - In order to support backup and restore functions, the range checking is done in such a way that the last minimum (i.e., VBAS/SBAS) or maximum (i.e., VMAX/SMAX) value entered is always valid. For example, if the minimum is entered and it exceeds the maximum, then the maximum is set to the new minimum value. Files modified: motorRecord.dbd, motorRecord.c 21) With MM4000 device support, a tweak request (TWF/TWR) occurring during the processing of a previous tweak request, would intermittently leave the MIP field in a nonzero state (i.e., mip = 0x20). A nonzero MIP field prevents processing a jog request. File modified: motorRecord.c Removed code that set DMOV TRUE. See do_work() under the following logic; IF DVAL field has changed IF the SET position field is OFF IF last dial commanded position = current dial feedback position. 22) An infinite home velocity was being issued if the MSTA "encoder present" bit was on, ERES=0 and UEIP=NO. File modified: init_record() in motorRecord.c; if ERES = 0, set ERES <- MRES. 23) Setting MRES negative could invalidated comparisons between BDST and RES. File modified: motorRecord.c - in postProcess(), (pmr->bdst != 0.0) to (|BDST| < |RES|). - in do_work(), (|BDST| < RES) to (|BDST| < |RES|). 24) Moved OMS device specific code that enforced VELO > VBAS from do_work() in motorRecord.c to oms_build_trans() in devOmsCom.c 25) No longer put MM4000 in "remote mode". User can do this by putting "MR;" in the INIT field. File modified: drvMM4000.c 26) MM4000_build_trans() in devMM4000.c was overflowing its character buffer (i.e., buff) when processing a LOAD_POS command. Increased buffer size to controller maximum (110) and added buffer overflow detection for both the local buffer and the "mess_node" message buffer. 27) Added model detection to MM4000/5 device driver. The long term plan is to have the same source code support both MM4000 and MM4005 controllers and use the "model" indicator to tailor the device driver support to either controller at run time. With this release the "model" variable is used to ignore (i.e. NO-OP) the LOAD_POS motor command for the MM4005. This is an interim solution until Newport releases controller firmware that explicitly supports a LOAD_POS command. Files modified: drvMMCom.h, drvMM4000.c and devMM4000.c 28) When a MM4000's motor resolution is small, the MM4000 communicates the motor's resolution in scientific notation. The MM4000 driver was not processing the number of significant decimal points correctly when the controller used scientific notation for the motor resolution. Files modified: motor_init() in drvMM400.c 29) Through an odd set of circumstances the Oms58 driver was not performing status updates on PowerPC (PPC) platforms. All users of the OMS VME58 controller on a PPC platform must upgrade to Motor Record version 4.0 for full functionality. Files modified: start_status() in drvOms58.c for (index = 0; index < total_cards; index++) { if((pmotor=(struct vmex_motor *) motor_state[card]->localaddr)!=0) ^ wrong | index 30) A "Controller communication error" bit was allocated in the MSTA field. Currently, only the MM4000/5 device driver sets this error indicator. Files modified: motor.h, drvMMCom.h, motorRecord.c, drvMM4000.c 31) The "soft_motor" task (i.e., Soft channel device driver support task) was nearly running out of stack space. Increased stack allocation from 1,000 to 5,000 bytes. Files modified: devSoftAux.c