.\" DO NOT MODIFY THIS FILE! It was generated by gdoc. .TH "gnutls_global_init" 3 "3.1.11" "gnutls" "gnutls" .SH NAME gnutls_global_init \- API function .SH SYNOPSIS .B #include .sp .BI "int gnutls_global_init( " void ");" .SH ARGUMENTS .IP " void" 12 .SH "DESCRIPTION" This function initializes the global data to defaults. In order to free resources you may call \fBgnutls_global_deinit()\fP when gnutls usage is no longer needed. Note that this function will also initialize the underlying crypto backend, if it has not been initialized before. This function increments a global counter, so that \fBgnutls_global_deinit()\fP only releases resources when it has been called as many times as \fBgnutls_global_init()\fP. This is useful when GnuTLS is used by more than one library in an application. This function can be called many times, but will only do something the first time. Note! This function is not thread safe. If two threads call this function simultaneously, they can cause a race between checking the global counter and incrementing it, causing both threads to execute the library initialization code. That would lead to a memory leak. To handle this, your application could invoke this function after aquiring a thread mutex. To ignore the potential memory leak is also an option. .SH "RETURNS" On success, \fBGNUTLS_E_SUCCESS\fP (0) is returned, otherwise a negative error code is returned. .SH "REPORTING BUGS" Report bugs to . .br General guidelines for reporting bugs: http://www.gnu.org/gethelp/ .br GnuTLS home page: http://www.gnu.org/software/gnutls/ .SH COPYRIGHT Copyright \(co 2012 Free Software Foundation, Inc.. .br Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. .SH "SEE ALSO" The full documentation for .B gnutls is maintained as a Texinfo manual. If the .B info and .B gnutls programs are properly installed at your site, the command .IP .B info gnutls .PP should give you access to the complete manual. As an alternative you may obtain the manual from: .IP .B http://www.gnu.org/software/gnutls/manual/ .PP