src/odbc/unittests/rpc

Main

Hostnamekrb5.freetds.io
uname -aLinux krb5.freetds.io 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux
date2025-10-24

==31784== Memcheck, a memory error detector
==31784== Copyright (C) 2002-2017, and GNU GPL'd, by Julian Seward et al.
==31784== Using Valgrind-3.13.0 and LibVEX; rerun with -h for copyright info
==31784== Command: ./rpc
==31784== 
--31784-- Valgrind options:
--31784--    --tool=memcheck
--31784--    --vgdb=no
--31784--    --num-callers=20
--31784--    --leak-check=yes
--31784--    -v
--31784--    --show-reachable=yes
--31784--    --log-fd=3
--31784--    --suppressions=/home/test/suppressions.supp
--31784--    --track-origins=yes
--31784-- Contents of /proc/version:
--31784--   Linux version 4.15.0-213-generic (buildd@lcy02-amd64-079) (gcc version 7.5.0 (Ubuntu 7.5.0-3ubuntu1~18.04)) #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023
--31784-- 
--31784-- Arch and hwcaps: AMD64, LittleEndian, amd64-cx16-lzcnt-rdtscp-sse3-avx-avx2-bmi
--31784-- Page sizes: currently 4096, max supported 4096
--31784-- Valgrind library directory: /usr/lib/valgrind
--31784-- Reading syms from /home/test/ftdstmp/ftds_comp99m/test4/src/odbc/unittests/rpc
--31784-- Reading syms from /lib/x86_64-linux-gnu/ld-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/ld-2.27.so ..
--31784--   .. CRC mismatch (computed 2977d8b2 wanted c64f09ed)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/ld-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /usr/lib/valgrind/memcheck-amd64-linux
--31784--   Considering /usr/lib/valgrind/memcheck-amd64-linux ..
--31784--   .. CRC mismatch (computed 41ddb025 wanted 9972f546)
--31784--    object doesn't have a symbol table
--31784--    object doesn't have a dynamic symbol table
--31784-- Scheduler: using generic scheduler lock implementation.
--31784-- Reading suppressions file: /home/test/suppressions.supp
--31784-- Reading suppressions file: /usr/lib/valgrind/default.supp
--31784-- REDIR: 0x4020d20 (ld-linux-x86-64.so.2:strlen) redirected to 0x580608c1 (???)
--31784-- REDIR: 0x4020b00 (ld-linux-x86-64.so.2:index) redirected to 0x580608db (???)
--31784-- Reading syms from /usr/lib/valgrind/vgpreload_core-amd64-linux.so
--31784--   Considering /usr/lib/valgrind/vgpreload_core-amd64-linux.so ..
--31784--   .. CRC mismatch (computed 50df1b30 wanted 4800a4cf)
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so
--31784--   Considering /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so ..
--31784--   .. CRC mismatch (computed f893b962 wanted 95ee359e)
--31784--    object doesn't have a symbol table
==31784== WARNING: new redirection conflicts with existing -- ignoring it
--31784--     old: 0x04020d20 (strlen              ) R-> (0000.0) 0x580608c1 ???
--31784--     new: 0x04020d20 (strlen              ) R-> (2007.0) 0x04c34db0 strlen
--31784-- REDIR: 0x401d540 (ld-linux-x86-64.so.2:strcmp) redirected to 0x4c35ee0 (strcmp)
--31784-- REDIR: 0x4021260 (ld-linux-x86-64.so.2:mempcpy) redirected to 0x4c394f0 (mempcpy)
--31784-- Reading syms from /home/test/ftdstmp/ftds_comp99m/src/odbc/.libs/libtdsodbc.so.0.0.0
--31784-- Reading syms from /lib/x86_64-linux-gnu/libpthread-2.27.so
--31784--   Considering /usr/lib/debug/.build-id/1f/06001733b9be9478b105faf0dac6bdf36c85de.debug ..
--31784--   .. build-id is valid
--31784-- Reading syms from /lib/x86_64-linux-gnu/libc-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libc-2.27.so ..
--31784--   .. CRC mismatch (computed f250d419 wanted 4aacab51)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libc-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libhogweed.so.4.5
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libgssapi_krb5.so.2.2
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libgnutls.so.30.14.10
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libnettle.so.6.5
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libgmp.so.10.3.2
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libkrb5.so.3.3
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libk5crypto.so.3.1
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /lib/x86_64-linux-gnu/libcom_err.so.2.1
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libkrb5support.so.0.1
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /lib/x86_64-linux-gnu/libz.so.1.2.11
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libp11-kit.so.0.3.0
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libidn2.so.0.3.3
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libunistring.so.2.1.0
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libtasn1.so.6.5.5
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /lib/x86_64-linux-gnu/libkeyutils.so.1.5
--31784--    object doesn't have a symbol table
--31784-- Reading syms from /lib/x86_64-linux-gnu/libresolv-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libresolv-2.27.so ..
--31784--   .. CRC mismatch (computed 0da9c5d1 wanted b111a73d)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libresolv-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /lib/x86_64-linux-gnu/libdl-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libdl-2.27.so ..
--31784--   .. CRC mismatch (computed 56b0b30d wanted 7867693f)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libdl-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/libffi.so.6.0.4
--31784--    object doesn't have a symbol table
--31784-- REDIR: 0x53e9a50 (libc.so.6:memmove) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8d60 (libc.so.6:strncpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9d30 (libc.so.6:strcasecmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e87b0 (libc.so.6:strcat) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8d90 (libc.so.6:rindex) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53eb480 (libc.so.6:rawmemchr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9bc0 (libc.so.6:mempcpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e99f0 (libc.so.6:bcmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8d20 (libc.so.6:strncmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8820 (libc.so.6:strcmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9b20 (libc.so.6:memset) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x5406db0 (libc.so.6:wcschr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8cc0 (libc.so.6:strnlen) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8890 (libc.so.6:strcspn) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9d80 (libc.so.6:strncasecmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8860 (libc.so.6:strcpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9ec0 (libc.so.6:memcpy@@GLIBC_2.14) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8dc0 (libc.so.6:strpbrk) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e87e0 (libc.so.6:index) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8c90 (libc.so.6:strlen) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53f3380 (libc.so.6:memrchr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9dd0 (libc.so.6:strcasecmp_l) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e99c0 (libc.so.6:memchr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x5407b70 (libc.so.6:wcslen) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9070 (libc.so.6:strspn) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9d00 (libc.so.6:stpncpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9cd0 (libc.so.6:stpcpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53eb4b0 (libc.so.6:strchrnul) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e9e20 (libc.so.6:strncasecmp_l) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x53e8cf0 (libc.so.6:strncat) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x547c700 (libc.so.6:__memcpy_chk) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x547c7d0 (libc.so.6:__memmove_chk) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
==31784== WARNING: new redirection conflicts with existing -- ignoring it
--31784--     old: 0x054d9980 (__memcpy_chk_avx_una) R-> (2030.0) 0x04c395e0 __memcpy_chk
--31784--     new: 0x054d9980 (__memcpy_chk_avx_una) R-> (2024.0) 0x04c38fa0 __memmove_chk
--31784-- REDIR: 0x53e9900 (libc.so.6:strstr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--31784-- REDIR: 0x54d9280 (libc.so.6:__strrchr_avx2) redirected to 0x4c34730 (rindex)
--31784-- REDIR: 0x54d9450 (libc.so.6:__strlen_avx2) redirected to 0x4c34cf0 (strlen)
--31784-- REDIR: 0x53e2020 (libc.so.6:malloc) redirected to 0x4c31aa0 (malloc)
--31784-- REDIR: 0x54d9990 (libc.so.6:__memcpy_avx_unaligned_erms) redirected to 0x4c386e0 (memmove)
--31784-- REDIR: 0x53f4b30 (libc.so.6:__strcmp_sse2_unaligned) redirected to 0x4c35da0 (strcmp)
--31784-- REDIR: 0x53e5050 (libc.so.6:calloc) redirected to 0x4c33a70 (calloc)
--31784-- REDIR: 0x54d8e60 (libc.so.6:__strchr_avx2) redirected to 0x4c34950 (index)
--31784-- REDIR: 0x54d9980 (libc.so.6:__memcpy_chk_avx_unaligned_erms) redirected to 0x4c395e0 (__memcpy_chk)
--31784-- REDIR: 0x53e2910 (libc.so.6:free) redirected to 0x4c32cd0 (free)
connecting
--31784-- REDIR: 0x54d03d0 (libc.so.6:__strncmp_sse42) redirected to 0x4c35570 (__strncmp_sse42)
--31784-- REDIR: 0x53e95a0 (libc.so.6:__GI_strstr) redirected to 0x4c39760 (__strstr_sse2)
--31784-- REDIR: 0x54d52e0 (libc.so.6:__memchr_avx2) redirected to 0x4c35f80 (memchr)
--31784-- REDIR: 0x54d51c0 (libc.so.6:__strspn_sse42) redirected to 0x4c39990 (strspn)
--31784-- REDIR: 0x54d4f30 (libc.so.6:__strcspn_sse42) redirected to 0x4c398d0 (strcspn)
--31784-- REDIR: 0x5401200 (libc.so.6:__strcpy_sse2_unaligned) redirected to 0x4c34dd0 (strcpy)
--31784-- REDIR: 0x54d5e40 (libc.so.6:__strcasecmp_avx) redirected to 0x4c355f0 (strcasecmp)
--31784-- REDIR: 0x54d9090 (libc.so.6:__strchrnul_avx2) redirected to 0x4c39020 (strchrnul)
--31784-- REDIR: 0x54d9970 (libc.so.6:__mempcpy_avx_unaligned_erms) redirected to 0x4c39130 (mempcpy)
--31784-- REDIR: 0x538dc40 (libc.so.6:setenv) redirected to 0x4c39de0 (setenv)
--31784-- REDIR: 0x53e3c50 (libc.so.6:realloc) redirected to 0x4c33cb0 (realloc)
odbctest
--------

connection parameters:
server:   'sql2008'
user:     'FREETDS\Administrator'
password: '????'
database: 'tempdb'
--31784-- REDIR: 0x5402810 (libc.so.6:__stpcpy_sse2_unaligned) redirected to 0x4c38200 (__stpcpy_sse2_unaligned)
--31784-- Reading syms from /lib/x86_64-linux-gnu/libnss_compat-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libnss_compat-2.27.so ..
--31784--   .. CRC mismatch (computed dc0305b8 wanted 460e4052)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnss_compat-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /lib/x86_64-linux-gnu/libnss_nis-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libnss_nis-2.27.so ..
--31784--   .. CRC mismatch (computed 38cb38d0 wanted 96404ac2)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnss_nis-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /lib/x86_64-linux-gnu/libnsl-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libnsl-2.27.so ..
--31784--   .. CRC mismatch (computed 12772991 wanted 58367bd1)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnsl-2.27.so ..
--31784--   .. CRC is valid
--31784-- Reading syms from /lib/x86_64-linux-gnu/libnss_files-2.27.so
--31784--   Considering /lib/x86_64-linux-gnu/libnss_files-2.27.so ..
--31784--   .. CRC mismatch (computed 2270a715 wanted a5763524)
--31784--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnss_files-2.27.so ..
--31784--   .. CRC is valid
--31784-- REDIR: 0x54041f0 (libc.so.6:__strcat_sse2_unaligned) redirected to 0x4c34990 (strcat)
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so
--31784--   Considering /usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so ..
--31784--   .. CRC mismatch (computed 83103428 wanted d26a1d18)
--31784--   Considering /usr/lib/debug/usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so ..
--31784--   .. CRC is valid
--31784-- REDIR: 0x54d9e10 (libc.so.6:__memset_avx2_unaligned_erms) redirected to 0x4c385d0 (memset)
--31784-- REDIR: 0x54d5a60 (libc.so.6:__memcmp_avx2_movbe) redirected to 0x4c37e00 (bcmp)
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/gconv/UTF-16.so
--31784--   Considering /usr/lib/x86_64-linux-gnu/gconv/UTF-16.so ..
--31784--   .. CRC mismatch (computed da5394b1 wanted a59039cd)
--31784--   Considering /usr/lib/debug/usr/lib/x86_64-linux-gnu/gconv/UTF-16.so ..
--31784--   .. CRC is valid
--31784-- REDIR: 0x54d74b0 (libc.so.6:__strncasecmp_avx) redirected to 0x4c356d0 (strncasecmp)
--31784-- Reading syms from /usr/lib/x86_64-linux-gnu/gconv/CP1252.so
--31784--   Considering /usr/lib/x86_64-linux-gnu/gconv/CP1252.so ..
--31784--   .. CRC mismatch (computed ba33c29d wanted cdb3aa71)
--31784--   Considering /usr/lib/debug/usr/lib/x86_64-linux-gnu/gconv/CP1252.so ..
--31784--   .. CRC is valid
use tempdb
Dropping procedure freetds_odbc_rpc_test
Creating procedure freetds_odbc_rpc_test
running test
executing SQLAllocStmt
executing SQLBindParameter for parameter 1
executing SQLBindParameter for parameter 2
executing SQLBindParameter for parameter 3
executing SQLBindParameter for parameter 4
executing SQLBindParameter for parameter 5
executing SQLBindParameter for parameter 6
executing SQLPrepare: {?=call freetds_odbc_rpc_test(?,?,?,?,?)}
executing SQLExecute
executing SQLNumResultCols for result set 1
executing SQLDescribeCol for 1 column 
--31784-- REDIR: 0x54d95e0 (libc.so.6:__strnlen_avx2) redirected to 0x4c34c90 (strnlen)
col   name             type  size scale nullable
----- --------------- ----- ----- ----- --------
1     name               -9   128     0        N
executing SQLFetch...
	name                          
	------------------------------
done.
0 rows expected, 0 found
executing SQLMoreResults...
executing SQLNumResultCols for result set 2
executing SQLDescribeCol for 1 column 
col   name             type  size scale nullable
----- --------------- ----- ----- ----- --------
1     type               12    30     0        Y
executing SQLFetch...
	type                          
	------------------------------
	char                          	( 4 bytes)
	int                           	( 3 bytes)
	text                          	( 4 bytes)
done.
3 rows expected, 3 found
executing SQLMoreResults...
executing SQLNumResultCols for result set 3
executing SQLDescribeCol for 1 column 
col   name             type  size scale nullable
----- --------------- ----- ----- ----- --------
1     name               12    30     0        Y
executing SQLFetch...
	name                          
	------------------------------
	bigint                        	( 6 bytes)
	binary                        	( 6 bytes)
	bit                           	( 3 bytes)
	char                          	( 4 bytes)
	date                          	( 4 bytes)
	datetime                      	( 8 bytes)
	datetime2                     	( 9 bytes)
	datetimeoffset                	(14 bytes)
	decimal                       	( 7 bytes)
	float                         	( 5 bytes)
	geography                     	( 9 bytes)
	geometry                      	( 8 bytes)
	hierarchyid                   	(11 bytes)
	image                         	( 5 bytes)
	int                           	( 3 bytes)
	money                         	( 5 bytes)
	nchar                         	( 5 bytes)
	ntext                         	( 5 bytes)
	numeric                       	( 7 bytes)
	nvarchar                      	( 8 bytes)
	real                          	( 4 bytes)
	smalldatetime                 	(13 bytes)
	smallint                      	( 8 bytes)
	smallmoney                    	(10 bytes)
	sql_variant                   	(11 bytes)
	sysname                       	( 7 bytes)
	text                          	( 4 bytes)
	time                          	( 4 bytes)
	timestamp                     	( 9 bytes)
	tinyint                       	( 7 bytes)
	uniqueidentifier              	(16 bytes)
	varbinary                     	( 9 bytes)
	varchar                       	( 7 bytes)
	xml                           	( 3 bytes)
done.
at least 15 rows expected, 34 found
executing SQLMoreResults...
done.
bound data for parameter 1 is 4 bytes: 42.
bound data for parameter 2 is 3 bytes: 'xml'.
bound data for parameter 3 is 6 bytes: 'bigint'.
bound data for parameter 4 is 4 bytes: 6381921.
bound data for parameter 5 is 4 bytes: 3.
executing SQLFreeStmt
dropping procedure
DROP PROCEDURE freetds_odbc_rpc_test
--31784-- Discarding syms at 0x905a710-0x905c25b in /usr/lib/x86_64-linux-gnu/gconv/UTF-16.so due to munmap()
Done.
--31784-- Discarding syms at 0x925e600-0x925f508 in /usr/lib/x86_64-linux-gnu/gconv/CP1252.so due to munmap()
--31784-- Discarding syms at 0x8e57600-0x8e58292 in /usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so due to munmap()
--31784-- Discarding syms at 0x86162a0-0x861c1ac in /lib/x86_64-linux-gnu/libnss_compat-2.27.so due to munmap()
--31784-- Discarding syms at 0x8821070-0x88280d9 in /lib/x86_64-linux-gnu/libnss_nis-2.27.so due to munmap()
--31784-- Discarding syms at 0x8a2f090-0x8a3c8a7 in /lib/x86_64-linux-gnu/libnsl-2.27.so due to munmap()
--31784-- Discarding syms at 0x8c47350-0x8c4dd8f in /lib/x86_64-linux-gnu/libnss_files-2.27.so due to munmap()
==31784== 
==31784== HEAP SUMMARY:
==31784==     in use at exit: 0 bytes in 0 blocks
==31784==   total heap usage: 2,735 allocs, 2,735 frees, 2,476,928 bytes allocated
==31784== 
==31784== All heap blocks were freed -- no leaks are possible
==31784== 
==31784== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
==31784== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)

Main