static PyObject *wrap_doStuff(P yObject *self, PyObject *args) {
// this will store the result in a Python object
PyObject *finalResult;
// get arguments from Python
char *result = 0;
char *in= 0;
char *aString = 0;
char *bString = 0;
MY_NUM *a;
MY_NUM *b;
int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString);
if (!ok) return 0;
// do work to get a and b
// count - returns an int; GetVal - returns a char *
a = GetVal(aString, count(aString, ","));
b = GetVal(bString, count(bString, ","));
// make function call, which returns a char *
result = doStuff(in, a, b);
// save result in Python string
finalResult = PyString_FromSt ring(result);
// free memory
PyMem_Free(resu lt);
PyMem_Free(a);
PyMem_Free(b);
// return the result as a Python string
return finalResult;
}
....from python I can call this function 4 times...works fine. WHen I
call it for the fifth time python.exe crashes. im thinking some memory
problem in the wrapper function perhaps...but I am not sure. The
actually C function, doStuff can be called 5, 6,7...N times without a
problem
so i know its gotta be my wrapper.
Any ideas? Thanks! 14 2737
update:
if I use C's free(result), free(a) free(b) instead of PyMem_Free...I
only get one successfuly use/call of doStuff.
i.e.
// this works
doStuff(...)
// python crashes here
doStuff(...)
Java and Swing wrote: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a; MY_NUM *b; int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a char * a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(resu lt); PyMem_Free(a); PyMem_Free(b);
// return the result as a Python string return finalResult; }
...from python I can call this function 4 times...works fine. WHen I call it for the fifth time python.exe crashes. im thinking some memory problem in the wrapper function perhaps...but I am not sure. The actually C function, doStuff can be called 5, 6,7...N times without a problem so i know its gotta be my wrapper.
Any ideas? Thanks!
one more update...
if I remove PyMem_Free and free(...) ...so no memory clean up...I can
still only call doStuff 4 times, the 5th attemp crashes Python.
Java and Swing wrote: update: if I use C's free(result), free(a) free(b) instead of PyMem_Free...I only get one successfuly use/call of doStuff.
i.e. // this works doStuff(...)
// python crashes here doStuff(...)
Java and Swing wrote: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a; MY_NUM *b; int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a char * a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(resu lt); PyMem_Free(a); PyMem_Free(b);
// return the result as a Python string return finalResult; }
...from python I can call this function 4 times...works fine. WHen I call it for the fifth time python.exe crashes. im thinking some memory problem in the wrapper function perhaps...but I am not sure. The actually C function, doStuff can be called 5, 6,7...N times without a problem so i know its gotta be my wrapper.
Any ideas? Thanks!
Op 2005-10-12, Java and Swing schreef <co*******@gmai l.com>: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a; MY_NUM *b; int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a char * a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(resu lt); PyMem_Free(a); PyMem_Free(b);
// return the result as a Python string return finalResult; }
...from python I can call this function 4 times...works fine. WHen I call it for the fifth time python.exe crashes. im thinking some memory problem in the wrapper function perhaps...but I am not sure. The actually C function, doStuff can be called 5, 6,7...N times without a problem so i know its gotta be my wrapper.
Any ideas? Thanks!
Well assuming your doStuff is a C function that knows nothing of python.
it might be the PyMem_Free(resu lt). http://docs.python.org/api/memoryInterface.html says the following:
void PyMem_Free(void *p)
Frees the memory block pointed to by p, which must have been
returned by a previous call to PyMem_Malloc() or PyMem_Realloc() .
Otherwise, or if PyMem_Free(p) has been called before, undefined
behavior occurs. If p is NULL, no operation is performed.
But your result wasn't allocated by a PyMem_Malloc, it was returned
to you by a C function.
--
Antoon Pardon
Antoon,
I just saw that to. I updated the code like so...
static PyObject *wrap_doStuff(P yObject *self, PyObject *args) {
// this will store the result in a Python object
PyObject *finalResult;
// get arguments from Python
char *result = 0;
char *in= 0;
char *aString = 0;
char *bString = 0;
MY_NUM *a = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); //
the array will be 20 long
MY_NUM *b = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); //
the array will be 20 long
int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString);
if (!ok) return 0;
// do work to get a and b
// count - returns an int; GetVal - returns a MY_NUM * (a pointer
to a MY_NUM array)
a = GetVal(aString, count(aString, ","));
b = GetVal(bString, count(bString, ","));
// make function call, which returns a char *
result = doStuff(in, a, b);
// save result in Python string
finalResult = PyString_FromSt ring(result);
// free memory
PyMem_Free(a);
PyMem_Free(b);
free(aString);
free(bString);
free(result);
// return the result as a Python string
return finalResult;
}
...as you can see, i malloc'ed memory, and free'd the memory. However,
I still have python crashing (after only 3 successful calls to
doStuff). And yes, doStuff is a plain C function...noth ing related to
Python.
Antoon Pardon wrote: Op 2005-10-12, Java and Swing schreef <co*******@gmai l.com>: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a; MY_NUM *b; int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a char * a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(resu lt); PyMem_Free(a); PyMem_Free(b);
// return the result as a Python string return finalResult; }
...from python I can call this function 4 times...works fine. WHen I call it for the fifth time python.exe crashes. im thinking some memory problem in the wrapper function perhaps...but I am not sure. The actually C function, doStuff can be called 5, 6,7...N times without a problem so i know its gotta be my wrapper.
Any ideas? Thanks!
Well assuming your doStuff is a C function that knows nothing of python. it might be the PyMem_Free(resu lt). http://docs.python.org/api/memoryInterface.html says the following:
void PyMem_Free(void *p) Frees the memory block pointed to by p, which must have been returned by a previous call to PyMem_Malloc() or PyMem_Realloc() . Otherwise, or if PyMem_Free(p) has been called before, undefined behavior occurs. If p is NULL, no operation is performed.
But your result wasn't allocated by a PyMem_Malloc, it was returned to you by a C function.
-- Antoon Pardon
Antoon,
I just saw that to. I updated the code like so...
static PyObject *wrap_doStuff(P yObject *self, PyObject *args) {
// this will store the result in a Python object
PyObject *finalResult;
// get arguments from Python
char *result = 0;
char *in= 0;
char *aString = 0;
char *bString = 0;
MY_NUM *a = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); //
the array will be 20 long
MY_NUM *b = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); //
the array will be 20 long
int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString);
if (!ok) return 0;
// do work to get a and b
// count - returns an int; GetVal - returns a MY_NUM * (a pointer
to a MY_NUM array)
a = GetVal(aString, count(aString, ","));
b = GetVal(bString, count(bString, ","));
// make function call, which returns a char *
result = doStuff(in, a, b);
// save result in Python string
finalResult = PyString_FromSt ring(result);
// free memory
PyMem_Free(a);
PyMem_Free(b);
free(aString);
free(bString);
free(result);
// return the result as a Python string
return finalResult;
}
...as you can see, i malloc'ed memory, and free'd the memory. However,
I still have python crashing (after only 3 successful calls to
doStuff). And yes, doStuff is a plain C function...noth ing related to
Python.
Antoon Pardon wrote: Op 2005-10-12, Java and Swing schreef <co*******@gmai l.com>: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a; MY_NUM *b; int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a char * a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(resu lt); PyMem_Free(a); PyMem_Free(b);
// return the result as a Python string return finalResult; }
...from python I can call this function 4 times...works fine. WHen I call it for the fifth time python.exe crashes. im thinking some memory problem in the wrapper function perhaps...but I am not sure. The actually C function, doStuff can be called 5, 6,7...N times without a problem so i know its gotta be my wrapper.
Any ideas? Thanks!
Well assuming your doStuff is a C function that knows nothing of python. it might be the PyMem_Free(resu lt). http://docs.python.org/api/memoryInterface.html says the following:
void PyMem_Free(void *p) Frees the memory block pointed to by p, which must have been returned by a previous call to PyMem_Malloc() or PyMem_Realloc() . Otherwise, or if PyMem_Free(p) has been called before, undefined behavior occurs. If p is NULL, no operation is performed.
But your result wasn't allocated by a PyMem_Malloc, it was returned to you by a C function.
-- Antoon Pardon
Sorry about the double post...
anyhow, after putting in debug statements I found that it was crashing
when it called, free(result)... .so I removed the free(result).
now it crashes when it gets to, b = GetVal(bString, count(bString,
","));
...any ideas?
Java and Swing wrote: Antoon, I just saw that to. I updated the code like so...
static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); // the array will be 20 long MY_NUM *b = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); // the array will be 20 long int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a MY_NUM * (a pointer to a MY_NUM array) a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(a); PyMem_Free(b); free(aString); free(bString); free(result);
// return the result as a Python string return finalResult; }
..as you can see, i malloc'ed memory, and free'd the memory. However, I still have python crashing (after only 3 successful calls to doStuff). And yes, doStuff is a plain C function...noth ing related to Python.
Antoon Pardon wrote: Op 2005-10-12, Java and Swing schreef <co*******@gmai l.com>: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a; MY_NUM *b; int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a char * a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(resu lt); PyMem_Free(a); PyMem_Free(b);
// return the result as a Python string return finalResult; }
...from python I can call this function 4 times...works fine. WHen I call it for the fifth time python.exe crashes. im thinking some memory problem in the wrapper function perhaps...but I am not sure. The actually C function, doStuff can be called 5, 6,7...N times without a problem so i know its gotta be my wrapper.
Any ideas? Thanks!
Well assuming your doStuff is a C function that knows nothing of python. it might be the PyMem_Free(resu lt). http://docs.python.org/api/memoryInterface.html says the following:
void PyMem_Free(void *p) Frees the memory block pointed to by p, which must have been returned by a previous call to PyMem_Malloc() or PyMem_Realloc() . Otherwise, or if PyMem_Free(p) has been called before, undefined behavior occurs. If p is NULL, no operation is performed.
But your result wasn't allocated by a PyMem_Malloc, it was returned to you by a C function.
-- Antoon Pardon
ok, further digging...I found that in the C function GetVal...it is
crashing where I try to malloc some memory. Note, I have no problems
when running this from C..just from Python using my wrapper.
GetVal looks something like..
MY_NUM *GetVal(const char *in, const int x) {
MY_NUM *results, *returnResults;
results = (MY_NUM *) malloc((x * sizeof(MY_NUM) + 1);
returnResults = results;
// ..do more work..
return returnResults;
}
I put in print statements into the C code and found that it is crashing
at the line where I malloc some space for "results".
....any ideas why this is crashing when calling from Python via C
wrapper?
Java and Swing wrote: Sorry about the double post...
anyhow, after putting in debug statements I found that it was crashing when it called, free(result)... .so I removed the free(result).
now it crashes when it gets to, b = GetVal(bString, count(bString, ","));
..any ideas?
Java and Swing wrote: Antoon, I just saw that to. I updated the code like so...
static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { // this will store the result in a Python object PyObject *finalResult;
// get arguments from Python char *result = 0; char *in= 0; char *aString = 0; char *bString = 0; MY_NUM *a = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); // the array will be 20 long MY_NUM *b = (MY_NUM *) PyMem_Malloc((2 0 * sizeof(MY_NUM) + 1); // the array will be 20 long int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); if (!ok) return 0;
// do work to get a and b // count - returns an int; GetVal - returns a MY_NUM * (a pointer to a MY_NUM array) a = GetVal(aString, count(aString, ",")); b = GetVal(bString, count(bString, ","));
// make function call, which returns a char * result = doStuff(in, a, b);
// save result in Python string finalResult = PyString_FromSt ring(result);
// free memory PyMem_Free(a); PyMem_Free(b); free(aString); free(bString); free(result);
// return the result as a Python string return finalResult; }
..as you can see, i malloc'ed memory, and free'd the memory. However, I still have python crashing (after only 3 successful calls to doStuff). And yes, doStuff is a plain C function...noth ing related to Python.
Antoon Pardon wrote: Op 2005-10-12, Java and Swing schreef <co*******@gmai l.com>: > static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { > // this will store the result in a Python object > PyObject *finalResult; > > // get arguments from Python > char *result = 0; > char *in= 0; > char *aString = 0; > char *bString = 0; > MY_NUM *a; > MY_NUM *b; > int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); > if (!ok) return 0; > > // do work to get a and b > // count - returns an int; GetVal - returns a char * > a = GetVal(aString, count(aString, ",")); > b = GetVal(bString, count(bString, ",")); > > // make function call, which returns a char * > result = doStuff(in, a, b); > > // save result in Python string > finalResult = PyString_FromSt ring(result); > > // free memory > PyMem_Free(resu lt); > PyMem_Free(a); > PyMem_Free(b); > > // return the result as a Python string > return finalResult; > } > > ...from python I can call this function 4 times...works fine. WHen I > call it for the fifth time python.exe crashes. im thinking some memory > problem in the wrapper function perhaps...but I am not sure. The > actually C function, doStuff can be called 5, 6,7...N times without a > problem > so i know its gotta be my wrapper. > > Any ideas? Thanks!
Well assuming your doStuff is a C function that knows nothing of python. it might be the PyMem_Free(resu lt). http://docs.python.org/api/memoryInterface.html says the following:
void PyMem_Free(void *p) Frees the memory block pointed to by p, which must have been returned by a previous call to PyMem_Malloc() or PyMem_Realloc() . Otherwise, or if PyMem_Free(p) has been called before, undefined behavior occurs. If p is NULL, no operation is performed.
But your result wasn't allocated by a PyMem_Malloc, it was returned to you by a C function.
-- Antoon Pardon
"Java and Swing" <co*******@gmai l.com> writes: static PyObject *wrap_doStuff(P yObject *self, PyObject *args) {
[...] char *aString = 0; char *bString = 0;
[...] int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString);
[...] free(aString); free(bString);
aString and bString are pointers to memory managed by the strings in
your args tuple. You must not free them! The memory is automatically
managed by Python.
Bernhard
--
Intevation GmbH http://intevation.de/
Skencil http://skencil.org/
Thuban http://thuban.intevation.org/
thanks for the tip, however even when I do not free aString or bString,
i'm still crashing at the malloc in the c function, not the wrapper.
Bernhard Herzog wrote: "Java and Swing" <co*******@gmai l.com> writes:
static PyObject *wrap_doStuff(P yObject *self, PyObject *args) { [...] char *aString = 0; char *bString = 0; [...] int ok = PyArg_ParseTupl e(args, "sss", &in, &aString, &bString); [...] free(aString); free(bString);
aString and bString are pointers to memory managed by the strings in your args tuple. You must not free them! The memory is automatically managed by Python.
Bernhard
-- Intevation GmbH http://intevation.de/ Skencil http://skencil.org/ Thuban http://thuban.intevation.org/ This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics |
by: Mark McEahern |
last post by:
I just wrote a very simple wrapper for the PayFlow Pro SDK (see below).
A friend of mine did this before, but I didn't have access to his
source, so I took it as a learning opportunity for me to write a C
wrapper. I did a little searching to see whether anyone had done
anything like this for Python. I didn't find anything.
I did find that PHP comes with an extension for PayFlow Pro that you can
compile into the language:
|
by: James S |
last post by:
Hi,
Basically I've been fighting with this code for a few days now and
can't seem to work around this problem. Included is the output, the
program I use to get this error and the source code for my wrapper.
This is acually part of the project, libxmlconf on sourceforge. The
newest working version isn't there yet, and cvs is lagged by 6 hours
or so. So if you think you want to have a try at this I can tgz the
source for you. My...
|
by: Garett Shulman |
last post by:
Hello, I am trying to create a wrapper for a function with the following
prototype:
int ap_get_playlist(int session, int *argc, char ***the_list);
I'm not quite sure how to construct the Py_BuildValue. I would like the
python function to return a list of strings. However, the length of the
list, (*argc in the function call), will vary at run time. Is it
possible to have a wrapper function return a list whose size is not know
at compile...
|
by: Egil M?ller |
last post by:
Is there any way to create transparent wrapper objects in Python?
I thought implementing __getattribute__ on either the wrapper class or
its metaclass would do the trick, but it does not work for the built
in operators:
class Foo(object):
class __metaclass__(type):
def __getattribute__(self, name):
print "Klass", name
|
by: Java and Swing |
last post by:
I am having trouble with a wrapper function...
My C code looks like
-----------------------
#include <stdlib.h>
#include <string.h>
#include "Python.h"
int doStuff(const char *input, const char *d) {...}
| |
by: Fredrik Tolf |
last post by:
If I have a variable which points to a function, can I check if certain
argument list matches what the function wants before or when calling it?
Currently, I'm trying to catch a TypeError when calling the function
(since that is what is raised when trying to call it with an illegal
list), but that has the rather undesirable side effect of also catching
any TypeErrors raised inside the function. Is there a way to avoid that?
Fredrik Tolf
|
by: andrew.gregory |
last post by:
If compiling a SWIG wrapper with MinGW 3.2.3 (Windows) get the
following compilation error:
pyprog_wrap.cxx: In function `int
SWIG_Python_ConvertFunctionPtr(PyObject*,
void**, swig_type_info*)':
pyprog_wrap.cxx:2051: invalid conversion from `const char*' to `char*'
Extract from wrapper:
|
by: GinTon |
last post by:
EyeDB is a free ODBMS based on the ODMG 3 specification with
programming interfaces for C++ and Java. It is very powerfull, mature,
safe and stable. In fact, it was developed in 1992 for the Genome View
project althought rewritten in 1994, and has been used in a lot of
bioinformatics projects
http://www.eyedb.org/
Python does not have any programming interface to ODBMS and I believe
that it would be very interesting that the Python...
|
by: andrew cooke |
last post by:
Hi,
Within Python (2.5):
Help on method-wrapper object:
__str__ = class method-wrapper(object)
| Methods defined here:
|
| __call__(...)
| x.__call__(...) <==x(...)
|
by: marktang |
last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However, people are often confused as to whether an ONU can Work As a Router. In this blog post, we’ll explore What is ONU, What Is Router, ONU & Router’s main usage, and What is the difference between ONU and Router. Let’s take a closer look !
Part I. Meaning of...
|
by: jinu1996 |
last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven tapestry of website design and digital marketing. It's not merely about having a website; it's about crafting an immersive digital experience that captivates audiences and drives business growth.
The Art of Business Website Design
Your website is...
| |
by: Hystou |
last post by:
Overview:
Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows Update option using the Control Panel or Settings app; it automatically checks for updates and installs any it finds, whether you like it or not. For most users, this new feature is actually very convenient. If you want to control the update process,...
|
by: tracyyun |
last post by:
Dear forum friends,
With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
|
by: TSSRALBI |
last post by:
Hello
I'm a network technician in training and I need your help.
I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs.
The last exercise I practiced was to create a LAN-to-LAN VPN between two Pfsense firewalls, by using IPSEC protocols.
I succeeded, with both firewalls in the same network. But I'm wondering if it's possible to do the same thing, with 2 Pfsense firewalls...
|
by: adsilva |
last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
|
by: 6302768590 |
last post by:
Hai team
i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated we have to send another system
|
by: muto222 |
last post by:
How can i add a mobile payment intergratation into php mysql website.
| |
by: bsmnconsultancy |
last post by:
In today's digital era, a well-designed website is crucial for businesses looking to succeed. Whether you're a small business owner or a large corporation in Toronto, having a strong online presence can significantly impact your brand's success. BSMN Consultancy, a leader in Website Development in Toronto offers valuable insights into creating effective websites that not only look great but also perform exceptionally well. In this comprehensive...
| | |