#1 Re: mORMot 2 » Memory leak in TDocVariant.CastTo » 2025-02-26 10:12:46

You are right, this method is equivalent to test(VariantSaveJson(jo)). The memory leak is gone.

#2 mORMot 2 » Memory leak in TDocVariant.CastTo » 2025-02-26 03:49:53

zen010101
Replies: 2

FPC 3.2_fix branch: 3.2.3-1404-g57e84ef714 [2024/11/20] for aarch64

Testing code:

procedure TMemoryLeakTest._VariantToUtf8;
var
  jo: variant;
  procedure test(const aUtf8String: RawUtf8);
  begin
    writeln(aUtf8String)
  end;
begin
  jo := _Obj(['name', 'tom']);
  test(jo);
end;

Memory leak report:

Call trace for block $0000007FA4A22A20 size 54
  $000000000041EDB4
  $000000000040F77C
  $0000000000410D9C
  $0000000000412218
  $00000000004BF804  Utf8ToWideString,  line 5606 of ../../../ccr/mORMot2/src/core/mormot.core.unicode.pas
  $00000000005F2AF0  RawUtf8ToVariant,  line 3985 of ../../../ccr/mORMot2/src/core/mormot.core.variants.pas
  $00000000005F7F40  CastTo,  line 5310 of ../../../ccr/mORMot2/src/core/mormot.core.variants.pas

There is no error on Windows but Linux-aarch64 。Is it a  FPC aarch64 compiler's bug or the Mormot bug ?

#3 mORMot 2 » ORM operation failed » 2025-02-16 00:20:48

zen010101
Replies: 1

After the execution of aDB.Backup(), all my ORM operations failed. Here is the error message:

ESqlite3Exception {Message:"Error SQLITE_MISUSE (21) [SELECT ID,Channelname,Url,Suburl,Tcpmode,Onvif,User,Password,Sipid,Sipstreams,Sipchannelname FROM Inputstream WHERE RowID=?] using 3.46.1 - bad parameter or other API misuse",ErrorCode:21,SQLite3ErrorCode:"secMISUSE"} [] at 53d310 ../../src/db/mormot.db.raw.sqlite3.pas  (5828) ../../src/db/mormot.db.raw.sqlite3.pas  (8642) ../../src/db/mormot.db.raw.sqlite3.pas  (8964) ....

Did I do something wrong?

#4 Re: mORMot 2 » Issue about .mab debug file » 2025-02-14 04:00:44

I finally know the reason.  My FPC + Linux combination doesn't work is because:

The .mab file I generated relies on the .dbg file, and the SmartLink option is automatically disabled during its creation. However, after generating the .mab file and subsequently switching to Release Mode (which explicitly enables SmartLink), the previously created .mab file becomes invalid. This occurs even when using the -Xm compilation flag to generate the .map file – the map2mab tool appears incompatible with Free Pascal Compiler (FPC)-generated .map files, throwing an "Error: EInOutError Read past end of file" during processing.

The root cause has been identified - SmartLink optimization invalidates the .mab file. This leads to another  question:

Could we make TDebugFile to extract line number and symbol information directly from FPC-generated .map files (created via the -Xm compilation flag)? or make map2mab work?

#5 Re: mORMot 2 » Issues about Remote Logging » 2025-02-13 16:41:02

I did some debugging, the reason I suspect might be : TSynLogFile.ProcessOneLine. It determines whether the log file contains ThreadID based on whether the first line of formal message contains '!'. The first message sent when starting the Server in Logview.exe is: '%00 info Remote Logging Server started on port % with root name "%"'.

However, I do not know how to modify TSynLogFile to dynamically adapt to log content.


BTW: This line has a bug:

      if LineBeg[fLineLevelOffset] = 'Z' then

should be

      if LineBeg[fLineLevelOffset-2] = 'Z' then

#6 Re: mORMot 2 » Logview.exe : only first day's log visible » 2025-02-13 16:26:22

I knew why. Because I put two formatted log contents into one. The first one is without a thread ID, but the other one had.

#7 mORMot 2 » Issues about Remote Logging » 2025-02-11 17:03:40

zen010101
Replies: 2

When TSynLog.Family.PerThreadLog := ptIdentifiedInOneFile will prevent messages from being sent to the remote LogView. I did not find any explanation in any documentation or code comments, is this a feature or bug?

#8 mORMot 2 » Logview.exe : only first day's log visible » 2025-02-07 03:26:58

zen010101
Replies: 1

I've run into a problem with logview.exe. When I use it to open a log file that's in Append mode (new logs keep getting added), it only shows the log info only the first day.
Even though there are logs from later days in the file, the tool just won't display them. But here's the strange part: when I delete the first day's data, it can then show all the other days' logs just fine.
The download link for the log file is:  https://nextcloud.cheming.top:4443/s/4xiJx6kyzY9CMcL

Anyone know what's going on?

#9 mORMot 2 » TSynLocker.LockedInt64Increment » 2025-02-03 18:08:35

zen010101
Replies: 1

TSynLocker.LockedInt64Increment return value is not the newly stored value, but the previous stored value.
This does not seem to match what is described in the comments.

#10 Re: mORMot 2 » Issue about CP_54936 converting » 2025-02-02 16:43:25

I committed a PR to fix some errors regarding the code page based on the results tested yesterday.

#11 Re: mORMot 2 » Issue about .mab debug file » 2025-02-01 16:21:44

Wired.

Here is my environment:

OS: Windows 11
Compiler: Free Pascal Compiler version 3.2.3-1404-g57e84ef714 [2024/11/20] for aarch64
Target: Linux  aarch64 (and Dwarf3 debug info)

Every time I delete the .mab file, I can see line number information in the Log.

How can I find some more useful information?

#12 Re: mORMot 2 » Issue about CP_54936 converting » 2025-02-01 12:57:52

I did some experiments, and the conclusion is as follows:
None of these three approaches seems to fully cover the test cases for the CJK encoding set of Python 3.12.


1. uconv (ICU lib) on debian

Match found: big5-utf8.txt with encoding ibm-1373
Match found: cp949-utf8.txt with encoding ibm-1363
Match found: euc_jp-utf8.txt with encoding ibm-33722
Match found: gb18030-utf8.txt with encoding ibm-1392
Match found: gb2312-utf8.txt with encoding ibm-1392
Match found: gbk-utf8.txt with encoding ibm-1392
Match found: iso2022_jp-utf8.txt with encoding ISO-2022-JP
Match found: iso2022_kr-utf8.txt with encoding ISO-2022-KR
Match found: shift_jis-utf8.txt with encoding ibm-942

Or you can use another set of aliases:

Match found: big5-utf8.txt with encoding ibm-1373_P100-2002
Match found: cp949-utf8.txt with encoding ibm-1363_P11B-1998
Match found: euc_jp-utf8.txt with encoding ibm-33722_P12A_P12A-2009_U2
Match found: gb18030-utf8.txt with encoding gb18030
Match found: gb2312-utf8.txt with encoding gb18030
Match found: gbk-utf8.txt with encoding gb18030
Match found: iso2022_jp-utf8.txt with encoding ISO_2022,locale=ja,version=0
Match found: iso2022_kr-utf8.txt with encoding ISO_2022, locale=ko, version=0
Match found: shift_jis-utf8.txt with encoding ibm-942_P12A-1999

The interesting thing about the HZ-GB2312 encoding is:

pi@NanoPi103:~/cjkencoding_test$ cat hz-HZ.out
~}This sentence is in ASCII.
The next sentence is in GB.~{<:Ky2;S{#,NpJ)l6HK!#~}Bye.
pi@NanoPi103:~/cjkencoding_test$ cat hz.txt
This sentence is in ASCII.
The next sentence is in GB.~{<:Ky2;S{#,NpJ)l6HK!#~}Bye.

Although uconv claims to support this encoding, compared to hz.txt, there are two additional characters at the beginning of hz.out: "~}"

2. iconv on debian

Match found: big5-utf8.txt with encoding BIG-5
Match found: big5hkscs-utf8.txt with encoding BIG5-HKSCS
Match found: cp949-utf8.txt with encoding CP949
Match found: euc_jisx0213-utf8.txt with encoding EUC-JISX0213
Match found: euc_jp-utf8.txt with encoding CSEUCPKDFMTJAPANESE
Match found: gb18030-utf8.txt with encoding GB18030
Match found: gb2312-utf8.txt with encoding CN-GB
Match found: gbk-utf8.txt with encoding CP936
Match found: iso2022_jp-utf8.txt with encoding CSISO2022JP
Match found: iso2022_kr-utf8.txt with encoding CSISO2022KR
Match found: johab-utf8.txt with encoding CP1361
Match found: shift_jis-utf8.txt with encoding CP932

3. Windows API

If we use the official list provided by Microsoft, the results are as follows:

hz.txt 52936
hz.txt 54936
gb18030.txt 52936
gb18030.txt 54936
big5.txt 932
big5.txt 936
big5.txt 950
big5.txt 10001
big5.txt 10002
big5.txt 20000
big5.txt 20001
big5.txt 20002
big5.txt 20003
big5.txt 20005
big5.txt 20932
big5.txt 50220
big5.txt 50221
big5.txt 50222
big5.txt 50229
big5.txt 65000
big5.txt 65001
cp949.txt 949
cp949.txt 65000
cp949.txt 65001
euc_jp.txt 932
euc_jp.txt 936
euc_jp.txt 10001
euc_jp.txt 20932
euc_jp.txt 50220
euc_jp.txt 50221
euc_jp.txt 50222
euc_jp.txt 65000
euc_jp.txt 65001
gb2312.txt 936
gb2312.txt 10008
gb2312.txt 20936
gb2312.txt 50227
gb2312.txt 65000
gb2312.txt 65001
gbk.txt 936
gbk.txt 65000
gbk.txt 65001
iso2022_jp.txt 932
iso2022_jp.txt 936
iso2022_jp.txt 10001
iso2022_jp.txt 20932
iso2022_jp.txt 50220
iso2022_jp.txt 50221
iso2022_jp.txt 50222
iso2022_jp.txt 65000
iso2022_jp.txt 65001
iso2022_kr.txt 949
iso2022_kr.txt 1361
iso2022_kr.txt 10003
iso2022_kr.txt 20949
iso2022_kr.txt 50225
iso2022_kr.txt 51949
iso2022_kr.txt 65000
iso2022_kr.txt 65001

#13 Re: mORMot 2 » Issue about .mab debug file » 2025-01-31 14:49:04

Supplementary Note:

The information I provided earlier was incorrect. Through today's testing, I found that whether on Windows or Linux, only the first run can obtain the program's line number information. As long as the .mab file is generated, in subsequent runs, the program will not be able to find the line number information as long as the .mab is loaded.

#14 Re: mORMot 2 » pigz support? » 2025-01-31 14:41:06

okoba wrote:

Then ZSTD is the way to go.

https://github.com/L-Angel/compress-demo

This is a comparison of several common compression algorithms, including Snappy and zstd. The conclusion is:

zstd is similar to snappy. And according to the test of ab, synlz is better than snappy. https://blog.synopse.info/?post/2017/08 … form-SynLZ

#15 Re: mORMot 2 » Issue about .mab debug file » 2025-01-30 09:48:33

Yeah, you're right! I tried it on Linux and it worked fine. The issue only popped up on my Windows 11.

But I'm curious, why did it work the first time I ran it?

#17 mORMot 2 » Issue about .mab debug file » 2025-01-30 09:08:07

zen010101
Replies: 7

To compile the LoggingTest.dpr project with debug information and generate a .map file with the FPC, followed by executing the program, a .mab debug file will be created. The log file will display the source line number during the initial execution. However, upon running the program a second time, it loads the .mab file but does not include the line numbers in the log file. This suggests there may be an issue with the .mab file. I have traced the problem for some time but have not found anything conclusive; the following statement consistently returns -1:

u := debug.FindUnit(offset, Line) 

#18 Re: mORMot 2 » Issue about CP_54936 converting » 2025-01-30 02:42:37

GetLastError returns 87: INVALID_PARAMETER

I compared the implementation code of FPC and mORMot with the WideCharToMultiByte API document, and found that:

The case statement in FullCodePage uses the same values as the API documentation, but the documentation states that the dwFlags parameter needs to be set to 0 when the codepage is equal to the specified value. However, mORMot and FullCodePage return value actually set lpDefaultChar to nil, which is optional according to the API documentation, and FPC has always set this parameter to nil.

In the end, I forced the lpDefaultChar parameter to nil, and the error disappeared.

#19 Re: mORMot 2 » Issue about CP_54936 converting » 2025-01-29 17:30:51

ab wrote:

The more test, the better.

I commited a PR to add BIG5 charset in Unicode_CodePageName function.

I tested the new code in linux with Python 3.12 cjkencoding files and all passed.

Here is my test code: https://gist.github.com/zen010101/4d667 … 970eb20495

It is very strange that on Windows, some test cases failed because certain language packs were not installed on my machine, but one test case FPC passed, while mORMot failed, code page 52936.

I wonder why this result occurs if mORMot and FPC both call the same Windows API ?

#20 Re: mORMot 2 » Issue about CP_54936 converting » 2025-01-29 11:25:56

It's the FPC "feature" :

if the source code saved as UTF8 , e.g. using {$codepage utf8} or saving in utf8 with BOM, the FPC will storage the string constants that contain non-ASCII characters as UTF-16 in the executable.

So, in your FreeBSD, writeln('ü') will output a UnicodeString actually but the console output codepage is UTF-8, so you got a '?' as the result.

But if you don't use UTF8 as source file encoding format, the FPC using CP_ACP , e.g. in linux it is UTF-8, to storage string constants.

#21 Re: mORMot 2 » Issue about CP_54936 converting » 2025-01-28 11:25:16

Now it passed my test on both Windows and Linux.

Thank you again. :-)

#22 Re: mORMot 2 » Issue about CP_54936 converting » 2025-01-28 00:32:58

ab wrote:

On Windows, this seems to be a WinAPI limitation.
The API returns INVALID_PARAMETER for codepage = 54936.

Which API do you use? If it is WideCharToMultiByte, I checked Microsoft's instructions, there is the following description:

Note  For the code page 65001 (UTF-8) or the code page 54936 (GB18030, Windows Vista and later), dwFlags must be set to either 0 or WC_ERR_INVALID_CHARS. Otherwise, the function fails with ERROR_INVALID_FLAGS.

If the above instructions are adjusted, if you still fail to succeed, I guess it may be the problem of not installing a language package.

Following the guidelines below to install the simplified Chinese language package:

https://support.microsoft.com/en-us/win … fc697cfca8


ab wrote:

Even SetCodePage() with convert=true returns ''.

FPC doesn't seem to call WinAPI, and on my Windows, I get the correct result with SetCodePage. I traced the FPC code a bit, and it seems that the final conversion code is this:

procedure Unicode2AnsiMove(source:punicodechar;var dest:RawByteString;cp : TSystemCodePage;len:SizeInt);

It is located in the "...\fpcsrc\rtl\objpas\fpwidestring.pp" unit file.

#23 Re: mORMot 2 » Issue about CP_54936 converting » 2025-01-27 17:12:44

I forgot to provide some information earlier: the issue I encountered is on Windows, and upon checking, it seems that the commit only involves POSIX systems and not Windows.

#24 mORMot 2 » Issue about CP_54936 converting » 2025-01-27 14:54:46

zen010101
Replies: 28

CP_54936 is an extension of CP_936, which is the GB18030 character set and encoding standard, it is a mandatory national standard in China.

In the code below, if you use the TSynAnsiConvert object to convert it, you will not get the correct result, but if you use the FPC SetCodePage method, there is no problem.

https://gist.github.com/zen010101/091b6 … p54936-pas


Suggest adding support for this Code Page, just like supporting CP_936.

More information about CP_54936: https://en.wikipedia.org/wiki/GB_18030

#25 Re: mORMot 2 » Issue about ConsoleWrite() » 2025-01-27 01:01:04

It works! The only disadvantage may be that the API is only called once, which is not very friendly to programs that adjust ConsoleOutputCP multiple times. However, this is also a balance between correctness and performance, which is understandable and acceptable.

Thanks again to ab. smile

#26 mORMot 2 » Issue about ConsoleWrite() » 2025-01-26 09:20:48

zen010101
Replies: 3

Look at this, where the Writeln statement outputs the correct string, but ConsoleWrite does not.
The reason is that ConsoleWrite internally calls Utf8ToConsole, which converts the string from UTF8 to CP_OEM.
The Writeln function will internally determine whether the code page of the Output is UTF8, and convert the string only if it is not.

code is here: https://gist.github.com/zen010101/fb6cb … le-bug-pas


I committed a PR for this: https://github.com/synopse/mORMot2/pull/337

#27 mORMot 2 » issue about PosIU() » 2025-01-19 15:37:22

zen010101
Replies: 1

see the code:

var
rawutf8str: RawUtf8 = '333你abc好33a';
...
writeln(PosI('ABC好',rawutf8str)); // result is 7
writeln(PosIU('ABC好',rawutf8str)); // result is 0, should be 7
synunistr := Utf8ToSynUnicode(rawutf8str);
writeln(Pos('abc好', synunistr)); // result is 5

PosIU() seems failed to find the substr.

#28 Re: mORMot 2 » How Can I Get Column FieldSize when I Use TSQLDBStatement Get ReCord? » 2025-01-10 03:44:28

gunix wrote:

in order to convert into Delphi TDataset, FieldDefs.Add( FieldName,FieldType,FieldSize,CanNull)

You can try the TSqlDBConnectionProperties.GetFields() method ab mentioned. This method outputs the field definition to the Fields parameter, which is a TSqlDBColumnDefineDynArray type. Each element contains the following information:

  TSqlDBColumnDefine = packed record
    /// the Column name
    ColumnName: RawUtf8;
    /// the Column type, as retrieved from the database provider
    // - returned as plain text by GetFields method, to be used e.g. by
    // TSqlDBConnectionProperties.GetFieldDefinitions method
    // - SqlCreate will check for this value to override the default type
    ColumnTypeNative: RawUtf8;
    /// the Column default width (in chars or bytes) of ftUtf8 or ftBlob
    // - can be set to value <0 for CLOB or BLOB column type, i.e. for
    // a value without any maximal length
    ColumnLength: PtrInt;
   ...
  end;

#30 Re: mORMot 2 » How to Detect Client Connection in THttpServer OnRequest Event? » 2025-01-09 10:48:46

ab wrote:

On which operating system?

Windows 11 64bit and Linux aarch64, server side;
Linux aarach64, client side.

#31 Re: mORMot 2 » How to Detect Client Connection in THttpServer OnRequest Event? » 2025-01-09 02:21:38

No matter THttpAsyncServer or THttpServer, the result is the same .

#32 Re: mORMot 2 » How to Detect Client Connection in THttpServer OnRequest Event? » 2025-01-09 02:19:38

I don't know if there is something wrong with me here. You can reproduce the situation on my end like this:


1. Use the official example httpServerRaw, only modify DoRequest to add some delay

function TSimpleHttpAsyncServer.DoOnRequest(Ctxt: THttpServerRequestAbstract): cardinal;
...
// POST = echo
Ctxt.OutContent := Ctxt.InContent;
Ctxt.OutContentType := TEXT_CONTENT_TYPE;
Writeln(Ctxt.ConnectionID, Ctxt.InContent);
Sleep(5000);
...

2. In TSimpleHttpAsyncServer.Create, use a thread pool of only 1 thread:

fHttpServer := THttpAsyncServer.Create(
'55555', nil, nil, '', 1, 30000,
[hsoNoXPoweredHeader,
hsoNoStats,
hsoHeadersInterning
hsoThreadSmooting
//, hsoLogVerbose
]);

3. On the client side, simply create 100 threads to send requests using TSimpleHttpClient:

procedure TtestHttpRequestThread.Execute;
...
FHttpClient := TSimpleHttpClient.Create(True);
Response := FHttpClient.Request(Uri, 'POST', Headers, Format(Params, [FID]), mimetype, 0);
Response := FHttpClient.Request(Uri, 'POST', Headers, Format(Params, [FID]), mimetype, 0);
FHttpClient.Free;

4. When the sending request is complete, press Ctrl-C to exit the client program.
On the server side, you can see that the server has finally processed all 100 requests.

#33 mORMot 2 » How to Detect Client Connection in THttpServer OnRequest Event? » 2025-01-08 18:30:52

zen010101
Replies: 7

Using THttpAsyncServer or THttpServer, in the OnRequest event handler function, how do I know whether the Client Socket is still connected? For example, the Client crashes after initiating many parallel requests, or other similar situations. I found that if a large number of concurrent requests flood into the server instantly, they will be placed in the PendingQueue and then processed by the thread pool, even if these subsequent connections have been Timeout or Closed.

#34 Re: mORMot 2 » High-Performance Frameworks » 2025-01-04 03:57:02

I'm in a similar situation.

Using the latest version of FPC Trunk 3.3.1-17174-g72a3729ca0 [2024/12/31] for x86_64 to compile mormot2tests, TTestCoreBase.FastStringCompare fails to run. Specifically, the shr code of strspn is incorrectly optimized. Only adding {$OPTIMIZATION OFF} works, but this makes FastStringCompare test twice as fast.

#36 mORMot 2 » TSynDictionary GPF error » 2024-12-29 04:29:05

zen010101
Replies: 3
  dict := TSynDictionary.New<RawUTF8, RawUTF8>(true);
  dict.Capacity := 64;
  dict.free;   

These simple code will cause a GPF error at

VarClearProc(Padding[i].Data)

with i = DIC_KEY.

#37 Re: mORMot 2 » sqlite build fails on aarch64 » 2024-12-03 16:37:07

If someone meets the same issue on Windows, see this : https://github.com/LongDirtyAnimAlf/fpc … issues/694

Download https://github.com/LongDirtyAnimAlf/fpc … ian_11.zip for compiling mORMot projects for linux-aarch64 target on Windows.

#38 Re: mORMot 2 » IPv4 and IPv6 » 2024-12-03 01:41:44

How can I make a TRestHttpServer to listen both of IPv4/6 ?

TRestHttpServer.Create(HttpPort, [SampleServer], '+', HTTP_DEFAULT_MODE, 4);

This will using http.sys and listen both 0.0.0.0 and [::].

TRestHttpServer.Create(HttpPort, [SampleServer], '+', WEBSOCKETS_DEFAULT_MODE, 4);

This will only listen 0.0.0.0

TRestHttpServer.Create('[::]:'+HttpPort, [SampleServer], '+', WEBSOCKETS_DEFAULT_MODE, 4);

This will only listen [::].

#39 mORMot 2 » IPv4 and IPv6 » 2024-12-02 15:48:35

zen010101
Replies: 3

How do I make a socket-based HTTP server listen for both 0.0.0.0 and [::] addresses? Just like http.sys.

#40 Re: mORMot 2 » Multi thread free memory using fpcx64mm » 2024-11-27 15:44:43

I tried on Windows 11, here is the result:

1. FPC Default MM

16 GB, 1 MB: 16384
Allocate: 16 GB in 21.29s i.e. 769.5 MB/s
FreeSingle: 16 GB in 613.26ms i.e. 26 GB/s
Allocate: 16 GB in 21.38s i.e. 766.1 MB/s
FreeMulti: 16 GB in 35.68ms i.e. 448.4 GB/s

16 GB, 4 MB: 4096
Allocate: 16 GB in 4.87s i.e. 3.2 GB/s
FreeSingle: 16 GB in 583.41ms i.e. 27.4 GB/s
Allocate: 16 GB in 4.45s i.e. 3.5 GB/s
FreeMulti: 16 GB in 33.54ms i.e. 477 GB/s

16 GB, 64 MB: 256
Allocate: 16 GB in 4.43s i.e. 3.6 GB/s
FreeSingle: 16 GB in 535.99ms i.e. 29.8 GB/s
Allocate: 16 GB in 3.89s i.e. 4.1 GB/s
FreeMulti: 16 GB in 42.48ms i.e. 376.6 GB/s

16 GB, 128 MB: 128
Allocate: 16 GB in 4.30s i.e. 3.7 GB/s
FreeSingle: 16 GB in 533.62ms i.e. 29.9 GB/s
Allocate: 16 GB in 3.90s i.e. 4 GB/s
FreeMulti: 16 GB in 68.81ms i.e. 232.4 GB/s

16 GB, 256 MB: 64
Allocate: 16 GB in 4.35s i.e. 3.6 GB/s
FreeSingle: 16 GB in 523.76ms i.e. 30.5 GB/s
Allocate: 16 GB in 3.86s i.e. 4.1 GB/s
FreeMulti: 16 GB in 134.51ms i.e. 118.9 GB/s

16 GB, 1 GB: 16
Allocate: 16 GB in 4.21s i.e. 3.8 GB/s
FreeSingle: 16 GB in 495.69ms i.e. 32.2 GB/s
Allocate: 16 GB in 3.83s i.e. 4.1 GB/s
FreeMulti: 16 GB in 36.50ms i.e. 438.2 GB/s

2. fpcx64mm

16 GB, 1 MB: 16384
Allocate: 16 GB in 3.99s i.e. 4 GB/s
FreeSingle: 16 GB in 564.80ms i.e. 28.3 GB/s
Allocate: 16 GB in 4s i.e. 3.9 GB/s
FreeMulti: 16 GB in 1.12s i.e. 14.2 GB/s

16 GB, 4 MB: 4096
Allocate: 16 GB in 3.96s i.e. 4 GB/s
FreeSingle: 16 GB in 610.13ms i.e. 26.2 GB/s
Allocate: 16 GB in 3.92s i.e. 4 GB/s
FreeMulti: 16 GB in 985.57ms i.e. 16.2 GB/s

16 GB, 64 MB: 256
Allocate: 16 GB in 3.86s i.e. 4.1 GB/s
FreeSingle: 16 GB in 518.28ms i.e. 30.8 GB/s
Allocate: 16 GB in 3.80s i.e. 4.2 GB/s
FreeMulti: 16 GB in 808.84ms i.e. 19.7 GB/s

16 GB, 128 MB: 128
Allocate: 16 GB in 3.85s i.e. 4.1 GB/s
FreeSingle: 16 GB in 488.24ms i.e. 32.7 GB/s
Allocate: 16 GB in 3.83s i.e. 4.1 GB/s
FreeMulti: 16 GB in 776.20ms i.e. 20.6 GB/s

16 GB, 256 MB: 64
Allocate: 16 GB in 3.89s i.e. 4.1 GB/s
FreeSingle: 16 GB in 541.66ms i.e. 29.5 GB/s
Allocate: 16 GB in 3.85s i.e. 4.1 GB/s
FreeMulti: 16 GB in 726.30ms i.e. 22 GB/s

16 GB, 1 GB: 16
Allocate: 16 GB in 3.83s i.e. 4.1 GB/s
FreeSingle: 16 GB in 518.28ms i.e. 30.8 GB/s
Allocate: 16 GB in 3.88s i.e. 4.1 GB/s
FreeMulti: 16 GB in 786.35ms i.e. 20.3 GB/s

The performance of FPC Default MM is very good, except for 2 issues: first, the speed of allocation in units of 1MB is indeed slow, but the speed of allocation in units of 4MB and above is comparable to fpcx64mm; second, memory is only released when the program is closed.
fpcx64mm Same as the problem described by @okoba, the speed of FreeMulti is not fast but slow.

#41 Re: mORMot 2 » Multi thread free memory using fpcx64mm » 2024-11-21 12:43:11

okoba wrote:

Default memory manager of FPC does not free it until closing the program or on reuse.

Yes, I meet the same issue. My program calls the web API 10,000 times, the memory always increases until I close the program. It reports no memory leaks. But when using fpcx64mm, the amount of memory is a fixed value.

P.S. the OS is windows. In aarach64, the memory manager of FPC is the same as fpcx64mm.

#42 Re: mORMot 2 » RestHttpServer with https » 2024-11-20 15:11:59

see source code:

/// create a HTTP/HTTPS Server instance, to serve REST requests
...
// - for a HTTPS server, use secTLS and set CertificateFile, PrivateKeyFile,
// and PrivateKeyPassword expected values, or specify secTLSSelfSigned
constructor Create(const aServers: array of TRestServer; const aPort: RawUtf8;
  aThreadPoolCount: integer = 32; aSecurity: TRestHttpServerSecurity = secNone;
  aOptions: TRestHttpServerOptions = HTTPSERVER_DEFAULT_OPTIONS;
  const CertificateFile: TFileName = ''; const PrivateKeyFile: TFileName = '';
  const PrivateKeyPassword: RawUtf8 = ''; const CACertificatesFile: TFileName = '');
    reintroduce; overload;

from the documentation

#43 Re: mORMot 2 » RestHttpServer with https » 2024-11-17 02:14:11

server:
  HttpServer := TRestHttpServer.Create(HttpPort, [SampleServer], '+', useBidirAsync, 4, secTLSSelfSigned);
client:
  HttpClient := TRestHttpClient.Create('localhost', HttpPort, Model, true);

#44 Re: mORMot 2 » Help for uses IDocList » 2024-11-17 01:41:31

var
  d1, d2: IDocDict;
  l: IDocList;
begin
  l := DocList(j);
  for d1 in l do
    for d2 in d1.L['phones'] do
      writeln(d2['number']);
end;    

#45 Re: mORMot 2 » Arnaud will be away for Holidays » 2024-11-14 02:13:31

Congratulations to mORMot 2 for winning the championship with a time of 1.261s in the 1BRC in Pascal competition! mORMot is the best! Pascal is the best!

https://github.com/ObjectPascal-Communi … me-ov-file

#46 Re: mORMot 2 » TSynDaemon/TSynDaemonSettings memory leak » 2024-11-12 05:02:00

ab wrote:

IIRC the Stop method should be reentrant.

Yes, that's right, the comment of the stop() method says so:

    /// inherited class should override this abstract method with proper process
    // - should do nothing if the daemon was not running (e.g. already stopped)
    procedure Stop; virtual; abstract;

#47 Re: mORMot 2 » TSynDaemon/TSynDaemonSettings memory leak » 2024-11-11 05:42:11

Please try this PR: https://github.com/synopse/mORMot2/pull/319


There are two reasons for this issue:

1. No call to TSampleDaemon.Free()
2. Even if called, an exception will occur because Free() will call Stop(), and this function has already been executed in the previous CommandLine() when the user presses the Enter key.

Solution:

1. In the Stop() method, check the Server status and skip execution if it is not running.
2. Call TSampleDaemon.Free() at the end of the program.

#48 Re: mORMot 2 » Different behaviour in variant to json » 2024-11-10 16:10:55

Here is some samples too:

   v := _Json('{"a":["1"],"b":"2"}');
   v.a.Delete(0);
   v.a.Add('02');
   v.a._ := '03'; // same as v.a.Add('03');

#49 Re: mORMot 2 » ClientRestoreCallbacks in TWebSocketProcessSettings » 2024-11-10 09:35:24

If you try this commit: https://github.com/synopse/mORMot2/comm … c7a417d929, you will see that the server-side OnWSClose() can now be called regardless of whether the client is normally or abnormally disconnected, so that the TMyService.CallbackReleased() event inherited from TInterfacedObject or TInterfacedObjectRest will be called correctly.

Of course, there is no problem with your current approach, which allows for greater flexibility in handling disconnected events.

#50 Re: mORMot 2 » THttpProxyServer Inquiry » 2024-11-10 09:20:42

Kabiri wrote:

Thank you @zen010101
I just didn't understand about the whitelist.

Sorry, I found that the WhiteIP property of THttpAccsptBan seems to only be able to contain one IP address that should not be banned.

    /// a 32-bit IP4 which should never be banned
    // - is set to cLocalhost32, i.e. 127.0.0.1, by default
    property WhiteIP: cardinal
      read fWhiteIP write fWhiteIP; 

Board footer

Powered by FluxBB