-
Notifications
You must be signed in to change notification settings - Fork 467
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support for run JSBSim instance in multi-thread environment #666
Comments
I'll take a look to see why the Messages queue is static and whether it can't be made non-static. Although note even if we make it non-static that doesn't mean the JSBSim code is thread safe. |
I create a temperary fix for this issues: Methods
Bypass
Issue Remain
|
Patch with unhandled static var, with comment 'FMPS' diff --git a/src/initialization/FGTrimAnalysis.cpp b/src/initialization/FGTrimAnalysis.cpp
index 9d8d2220..2678c8af 100644
--- a/src/initialization/FGTrimAnalysis.cpp
+++ b/src/initialization/FGTrimAnalysis.cpp
@@ -1812,7 +1812,7 @@ double Objective::myCostFunctionFull(Vector<double> & x) // x variations come fr
+ 0.010*qDot*qDot
+ 0.010*rDot*rDot;
- static int count = 0;
+ static int count = 0; // FMPS
count++;
if ( f < TrimAnalysis->GetCostFunctionValue() )
@@ -1974,7 +1974,7 @@ double Objective::myCostFunctionFullWingsLevel(Vector<double> & x) // x variatio
+ 0.010*qDot*qDot
+ 0.010*rDot*rDot;
- static int count = 0;
+ static int count = 0; // FMPS
count++;
if ( f < TrimAnalysis->GetCostFunctionValue() )
@@ -2130,7 +2130,7 @@ double Objective::myCostFunctionLongitudinal(Vector<double> & x)
0.010
*qDot*qDot;
- static int count = 0;
+ static int count = 0; // FMPS
count++;
if ( f < TrimAnalysis->GetCostFunctionValue() )
@@ -2298,7 +2298,7 @@ double Objective::myCostFunctionFullCoordinatedTurn(Vector<double> & x)
+ 0.010*qDot*qDot
+ 0.010*rDot*rDot;
- static int count = 0;
+ static int count = 0; // FMPS
count++;
if ( f < TrimAnalysis->GetCostFunctionValue() )
@@ -2464,7 +2464,7 @@ double Objective::myCostFunctionFullTurn(Vector<double> & x)
+ 0.010*qDot*qDot
+ 0.010*rDot*rDot;
- static int count = 0;
+ static int count = 0; // FMPS
count++;
if ( f < TrimAnalysis->GetCostFunctionValue() )
@@ -2622,7 +2622,7 @@ double Objective::myCostFunctionPullUp(Vector<double> & x)
+ 0.010*qDot*qDot
+ 0.010*rDot*rDot;
- static int count = 0;
+ static int count = 0; // FMPS
count++;
if ( f < TrimAnalysis->GetCostFunctionValue() )
diff --git a/src/input_output/FGXMLElement.h b/src/input_output/FGXMLElement.h
index c53e2bf9..716d5712 100644
--- a/src/input_output/FGXMLElement.h
+++ b/src/input_output/FGXMLElement.h
@@ -394,8 +394,8 @@ private:
std::string file_name;
int line_number;
typedef std::map <std::string, std::map <std::string, double> > tMapConvert;
- static tMapConvert convert;
- static bool converterIsInitialized;
+ static tMapConvert convert; // FMPS
+ static bool converterIsInitialized; // FMPS
};
} // namespace JSBSim
diff --git a/src/models/FGAtmosphere.h b/src/models/FGAtmosphere.h
index 132e4c3f..4ece620a 100644
--- a/src/models/FGAtmosphere.h
+++ b/src/models/FGAtmosphere.h
@@ -267,7 +267,7 @@ protected:
*/
static constexpr double g0 = 9.80665 / fttom;
/// Specific gas constant for air - ft*lbf/slug/R
- static double Reng;
+ static double Reng; // FMPS
//@}
static constexpr double SHRatio = 1.4;
diff --git a/src/models/atmosphere/FGWinds.cpp b/src/models/atmosphere/FGWinds.cpp
index 736dddb8..e012bc12 100644
--- a/src/models/atmosphere/FGWinds.cpp
+++ b/src/models/atmosphere/FGWinds.cpp
@@ -285,7 +285,7 @@ void FGWinds::Turbulence(double h)
xi_v_km1 = 0, xi_v_km2 = 0, nu_v_km1 = 0, nu_v_km2 = 0,
xi_w_km1 = 0, xi_w_km2 = 0, nu_w_km1 = 0, nu_w_km2 = 0,
xi_p_km1 = 0, nu_p_km1 = 0,
- xi_q_km1 = 0, xi_r_km1 = 0;
+ xi_q_km1 = 0, xi_r_km1 = 0; // FMPS
double
diff --git a/src/simgear/magvar/coremag.cxx b/src/simgear/magvar/coremag.cxx
index 3954edaf..1fe4778c 100644
--- a/src/simgear/magvar/coremag.cxx
+++ b/src/simgear/magvar/coremag.cxx
@@ -158,15 +158,15 @@ static const double htnm_wmm2005[13][13]=
static const int nmax = 12;
-static double P[13][13];
-static double DP[13][13];
-static double gnm[13][13];
-static double hnm[13][13];
-static double sm[13];
-static double cm[13];
+static double P[13][13]; // FMPS
+static double DP[13][13]; // FMPS
+static double gnm[13][13]; // FMPS
+static double hnm[13][13]; // FMPS
+static double sm[13]; // FMPS
+static double cm[13]; // FMPS
-static double root[13];
-static double roots[13][13][2];
+static double root[13]; // FMPS
+static double roots[13][13][2]; // FMPS
/* Convert date to Julian day 1950-2049 */
unsigned long int yymmdd_to_julian_days( int yy, int mm, int dd )
@@ -199,7 +199,7 @@ double calc_magvar( double lat, double lon, double h, long dat, double* field )
double yearfrac,sr,r,theta,c,s,psi,fn,fn_0,B_r,B_theta,B_phi,X,Y,Z;
double sinpsi, cospsi, inv_s;
- static int been_here = 0;
+ static int been_here = 0; // FMPS
double sinlat = sin(lat);
double coslat = cos(lat);
|
Honestly, I don't know what Lines 546 to 551 in 0e842e7
Lines 563 to 568 in 0e842e7
Both of these occurrences could be replaced by a simple call to |
Not only this design is uglier than the static variables but in addition it breaks the API backward compatibility.
The variable
That's a good point. |
You're perfectly correct in raising all these usage of the
All in all, I'm pretty sure the Sorry for having rejected your PR but I'd suggest that we address the topic using modern C++ features rather than using one big chunk of data that would store all sort of unrelated data and break the API backward compatibility in the process. |
It’s been a long time since that code was written. However, I believe the code was simply to give an indication of whether the landing gear had made contact with the runway, and possibly if it had left the runway, too. There may be other ways to do this. The FGJSBBase::Message term was supposed to provide a way for the various modules to communicate with each other, but it could be that the reasoning for that is no longer valid. It was a pretty early capability. Could try to remove it and see what happens. A notification of landing gear contact could probably be done in a script using notifications. |
Thanks for the quick responce on this. Yes, the temporary fix is bad idea, and definitly not the right way to go. It's just a day saver for me at the moment. I'm glad we are on the right track. Hope the right solution will coming out in the near future. |
The feature was almost unused in JSBSim and it was using `static` members which are difficult to manage in a multi-threaded environment.
The feature was almost unused in JSBSim and it was using `static` members which are difficult to manage in a multi-threaded environment.
…ibrary to generate random numbers. (JSBSim-Team#715) This addresses the issue JSBSim-Team#666.
* Fix `SetTemperatureSL()` and `SetPressureSL()` which did not update the sea level density and speed of sound. * Make `Reng` a non `static` member (see JSBSim-Team#666). This was useless and prevented `Reng` from being accessed when JSBSim was compiled as a DLL.
* [WIP] Add a unit test for `FGAtmosphere` * Bug fixes * Fix `SetTemperatureSL()` and `SetPressureSL()` which did not update the sea level density and speed of sound. * Make `Reng` a non `static` member (see #666). This was useless and prevented `Reng` from being accessed when JSBSim was compiled as a DLL. * Forgot `JSBSIM_API`. * Increased the code coverage and fixed some bugs in the process.
* [WIP] Add a unit test for `FGAtmosphere` * Bug fixes * Fix `SetTemperatureSL()` and `SetPressureSL()` which did not update the sea level density and speed of sound. * Make `Reng` a non `static` member (see JSBSim-Team#666). This was useless and prevented `Reng` from being accessed when JSBSim was compiled as a DLL. * Forgot `JSBSIM_API`. * Increased the code coverage and fixed some bugs in the process.
Can someone list what are the relevant tasks for this, I want to pick one or two if possible. |
The specific issue with regards to the message queue was resolved via the following commit - 0e3b025 |
I have another bug I'd like to report which would be under the same 'epic'. When I create a bunch of JSBSim simulations in parallel (within a single process), I commonly get a deserialisation error, which reads like...
which obviously seems suspicious. I assume this is due to some buffer being shared between multiple instances of the deserialiser? I can workaround by mutexing creation of the simulator, but worry that there's some deeper down bug. |
The following doesn't appear thread safe. jsbsim/src/input_output/FGXMLElement.h Lines 397 to 398 in e33e184
So on line 60 below thread 1 sets jsbsim/src/input_output/FGXMLElement.cpp Lines 52 to 66 in e33e184
|
Describe the issue
I'm a developer, and used JSBSim as a C++ static library for a quiet long time. Everything works like a charms, until i try to run mutilple JSBSim instance conurrently. It will crash sometimes. After some debugging, i found that the message queue in FGJSBBase in a static variable. The thread try to pop a empty queue which clear by other thread lead to this issue.
static std::queue <Message> Messages;
So i'd like to request a feature to support run JSBSim in multi-thread env.
Why not use multi-process for isolation? The communication is hard and heavy for my situation.
Environment:
Other information
same type issue as #201
The text was updated successfully, but these errors were encountered: