cjson
fuzzing
inputs
test1 test10 test11 test2 test3 test3.bu test3.uf test3.uu test4 test5 test6 test7 test8 test9library_config
cJSONConfig.cmake.in cJSONConfigVersion.cmake.in libcjson.pc.in libcjson_utils.pc.in uninstall.cmaketests
inputs
test1 test1.expected test10 test10.expected test11 test11.expected test2 test2.expected test3 test3.expected test4 test4.expected test5 test5.expected test6 test7 test7.expected test8 test8.expected test9 test9.expectedjson-patch-tests
.editorconfig .gitignore .npmignore README.md cjson-utils-tests.json package.json spec_tests.json tests.jsonunity
auto
colour_prompt.rb colour_reporter.rb generate_config.yml generate_module.rb generate_test_runner.rb parse_output.rb stylize_as_junit.rb test_file_filter.rb type_sanitizer.rb unity_test_summary.py unity_test_summary.rb unity_to_junit.pydocs
ThrowTheSwitchCodingStandard.md UnityAssertionsCheatSheetSuitableforPrintingandPossiblyFraming.pdf UnityAssertionsReference.md UnityConfigurationGuide.md UnityGettingStartedGuide.md UnityHelperScriptsGuide.md license.txtexamples
unity_config.hcurl
.github
scripts
cleancmd.pl cmp-config.pl cmp-pkg-config.sh codespell-ignore.words codespell.sh distfiles.sh pyspelling.words pyspelling.yaml randcurl.pl requirements-docs.txt requirements-proselint.txt requirements.txt shellcheck-ci.sh shellcheck.sh spellcheck.curl trimmarkdownheader.pl typos.sh typos.toml verify-examples.pl verify-synopsis.pl yamlcheck.sh yamlcheck.yamlworkflows
appveyor-status.yml checkdocs.yml checksrc.yml checkurls.yml codeql.yml configure-vs-cmake.yml curl-for-win.yml distcheck.yml fuzz.yml http3-linux.yml label.yml linux-old.yml linux.yml macos.yml non-native.yml windows.ymlCMake
CurlSymbolHiding.cmake CurlTests.c FindBrotli.cmake FindCares.cmake FindGSS.cmake FindGnuTLS.cmake FindLDAP.cmake FindLibbacktrace.cmake FindLibgsasl.cmake FindLibidn2.cmake FindLibpsl.cmake FindLibssh.cmake FindLibssh2.cmake FindLibuv.cmake FindMbedTLS.cmake FindNGHTTP2.cmake FindNGHTTP3.cmake FindNGTCP2.cmake FindNettle.cmake FindQuiche.cmake FindRustls.cmake FindWolfSSL.cmake FindZstd.cmake Macros.cmake OtherTests.cmake PickyWarnings.cmake Utilities.cmake cmake_uninstall.in.cmake curl-config.in.cmake unix-cache.cmake win32-cache.cmakedocs
cmdline-opts
.gitignore CMakeLists.txt MANPAGE.md Makefile.am Makefile.inc _AUTHORS.md _BUGS.md _DESCRIPTION.md _ENVIRONMENT.md _EXITCODES.md _FILES.md _GLOBBING.md _NAME.md _OPTIONS.md _OUTPUT.md _PROGRESS.md _PROTOCOLS.md _PROXYPREFIX.md _SEEALSO.md _SYNOPSIS.md _URL.md _VARIABLES.md _VERSION.md _WWW.md abstract-unix-socket.md alt-svc.md anyauth.md append.md aws-sigv4.md basic.md ca-native.md cacert.md capath.md cert-status.md cert-type.md cert.md ciphers.md compressed-ssh.md compressed.md config.md connect-timeout.md connect-to.md continue-at.md cookie-jar.md cookie.md create-dirs.md create-file-mode.md crlf.md crlfile.md curves.md data-ascii.md data-binary.md data-raw.md data-urlencode.md data.md delegation.md digest.md disable-eprt.md disable-epsv.md disable.md disallow-username-in-url.md dns-interface.md dns-ipv4-addr.md dns-ipv6-addr.md dns-servers.md doh-cert-status.md doh-insecure.md doh-url.md dump-ca-embed.md dump-header.md ech.md egd-file.md engine.md etag-compare.md etag-save.md expect100-timeout.md fail-early.md fail-with-body.md fail.md false-start.md follow.md form-escape.md form-string.md form.md ftp-account.md ftp-alternative-to-user.md ftp-create-dirs.md ftp-method.md ftp-pasv.md ftp-port.md ftp-pret.md ftp-skip-pasv-ip.md ftp-ssl-ccc-mode.md ftp-ssl-ccc.md ftp-ssl-control.md get.md globoff.md happy-eyeballs-timeout-ms.md haproxy-clientip.md haproxy-protocol.md head.md header.md help.md hostpubmd5.md hostpubsha256.md hsts.md http0.9.md http1.0.md http1.1.md http2-prior-knowledge.md http2.md http3-only.md http3.md ignore-content-length.md insecure.md interface.md ip-tos.md ipfs-gateway.md ipv4.md ipv6.md json.md junk-session-cookies.md keepalive-cnt.md keepalive-time.md key-type.md key.md knownhosts.md krb.md libcurl.md limit-rate.md list-only.md local-port.md location-trusted.md location.md login-options.md mail-auth.md mail-from.md mail-rcpt-allowfails.md mail-rcpt.md mainpage.idx manual.md max-filesize.md max-redirs.md max-time.md metalink.md mptcp.md negotiate.md netrc-file.md netrc-optional.md netrc.md next.md no-alpn.md no-buffer.md no-clobber.md no-keepalive.md no-npn.md no-progress-meter.md no-sessionid.md noproxy.md ntlm-wb.md ntlm.md oauth2-bearer.md out-null.md output-dir.md output.md parallel-immediate.md parallel-max-host.md parallel-max.md parallel.md pass.md path-as-is.md pinnedpubkey.md post301.md post302.md post303.md preproxy.md progress-bar.md proto-default.md proto-redir.md proto.md proxy-anyauth.md proxy-basic.md proxy-ca-native.md proxy-cacert.md proxy-capath.md proxy-cert-type.md proxy-cert.md proxy-ciphers.md proxy-crlfile.md proxy-digest.md proxy-header.md proxy-http2.md proxy-insecure.md proxy-key-type.md proxy-key.md proxy-negotiate.md proxy-ntlm.md proxy-pass.md proxy-pinnedpubkey.md proxy-service-name.md proxy-ssl-allow-beast.md proxy-ssl-auto-client-cert.md proxy-tls13-ciphers.md proxy-tlsauthtype.md proxy-tlspassword.md proxy-tlsuser.md proxy-tlsv1.md proxy-user.md proxy.md proxy1.0.md proxytunnel.md pubkey.md quote.md random-file.md range.md rate.md raw.md referer.md remote-header-name.md remote-name-all.md remote-name.md remote-time.md remove-on-error.md request-target.md request.md resolve.md retry-all-errors.md retry-connrefused.md retry-delay.md retry-max-time.md retry.md sasl-authzid.md sasl-ir.md service-name.md show-error.md show-headers.md sigalgs.md silent.md skip-existing.md socks4.md socks4a.md socks5-basic.md socks5-gssapi-nec.md socks5-gssapi-service.md socks5-gssapi.md socks5-hostname.md socks5.md speed-limit.md speed-time.md ssl-allow-beast.md ssl-auto-client-cert.md ssl-no-revoke.md ssl-reqd.md ssl-revoke-best-effort.md ssl-sessions.md ssl.md sslv2.md sslv3.md stderr.md styled-output.md suppress-connect-headers.md tcp-fastopen.md tcp-nodelay.md telnet-option.md tftp-blksize.md tftp-no-options.md time-cond.md tls-earlydata.md tls-max.md tls13-ciphers.md tlsauthtype.md tlspassword.md tlsuser.md tlsv1.0.md tlsv1.1.md tlsv1.2.md tlsv1.3.md tlsv1.md tr-encoding.md trace-ascii.md trace-config.md trace-ids.md trace-time.md trace.md unix-socket.md upload-file.md upload-flags.md url-query.md url.md use-ascii.md user-agent.md user.md variable.md verbose.md version.md vlan-priority.md write-out.md xattr.mdexamples
.checksrc .gitignore 10-at-a-time.c CMakeLists.txt Makefile.am Makefile.example Makefile.inc README.md adddocsref.pl address-scope.c altsvc.c anyauthput.c block_ip.c cacertinmem.c certinfo.c chkspeed.c connect-to.c cookie_interface.c crawler.c debug.c default-scheme.c ephiperfifo.c evhiperfifo.c externalsocket.c fileupload.c ftp-delete.c ftp-wildcard.c ftpget.c ftpgetinfo.c ftpgetresp.c ftpsget.c ftpupload.c ftpuploadfrommem.c ftpuploadresume.c getinfo.c getinmemory.c getredirect.c getreferrer.c ghiper.c headerapi.c hiperfifo.c hsts-preload.c htmltidy.c htmltitle.cpp http-options.c http-post.c http2-download.c http2-pushinmemory.c http2-serverpush.c http2-upload.c http3-present.c http3.c httpcustomheader.c httpput-postfields.c httpput.c https.c imap-append.c imap-authzid.c imap-copy.c imap-create.c imap-delete.c imap-examine.c imap-fetch.c imap-list.c imap-lsub.c imap-multi.c imap-noop.c imap-search.c imap-ssl.c imap-store.c imap-tls.c interface.c ipv6.c keepalive.c localport.c log_failed_transfers.c maxconnects.c multi-app.c multi-debugcallback.c multi-double.c multi-event.c multi-formadd.c multi-legacy.c multi-post.c multi-single.c multi-uv.c netrc.c parseurl.c persistent.c pop3-authzid.c pop3-dele.c pop3-list.c pop3-multi.c pop3-noop.c pop3-retr.c pop3-ssl.c pop3-stat.c pop3-tls.c pop3-top.c pop3-uidl.c post-callback.c postinmemory.c postit2-formadd.c postit2.c progressfunc.c protofeats.c range.c resolve.c rtsp-options.c sendrecv.c sepheaders.c sessioninfo.c sftpget.c sftpuploadresume.c shared-connection-cache.c simple.c simplepost.c simplessl.c smooth-gtk-thread.c smtp-authzid.c smtp-expn.c smtp-mail.c smtp-mime.c smtp-multi.c smtp-ssl.c smtp-tls.c smtp-vrfy.c sslbackend.c synctime.c threaded.c unixsocket.c url2file.c urlapi.c usercertinmem.c version-check.pl websocket-cb.c websocket-updown.c websocket.c xmlstream.cinternals
BUFQ.md BUFREF.md CHECKSRC.md CLIENT-READERS.md CLIENT-WRITERS.md CODE_STYLE.md CONNECTION-FILTERS.md CREDENTIALS.md CURLX.md DYNBUF.md HASH.md LLIST.md MID.md MQTT.md MULTI-EV.md NEW-PROTOCOL.md PEERS.md PORTING.md RATELIMITS.md README.md SCORECARD.md SPLAY.md STRPARSE.md THRDPOOL-AND-QUEUE.md TIME-KEEPING.md TLS-SESSIONS.md UINT_SETS.md WEBSOCKET.mdlibcurl
opts
CMakeLists.txt CURLINFO_ACTIVESOCKET.md CURLINFO_APPCONNECT_TIME.md CURLINFO_APPCONNECT_TIME_T.md CURLINFO_CAINFO.md CURLINFO_CAPATH.md CURLINFO_CERTINFO.md CURLINFO_CONDITION_UNMET.md CURLINFO_CONNECT_TIME.md CURLINFO_CONNECT_TIME_T.md CURLINFO_CONN_ID.md CURLINFO_CONTENT_LENGTH_DOWNLOAD.md CURLINFO_CONTENT_LENGTH_DOWNLOAD_T.md CURLINFO_CONTENT_LENGTH_UPLOAD.md CURLINFO_CONTENT_LENGTH_UPLOAD_T.md CURLINFO_CONTENT_TYPE.md CURLINFO_COOKIELIST.md CURLINFO_EARLYDATA_SENT_T.md CURLINFO_EFFECTIVE_METHOD.md CURLINFO_EFFECTIVE_URL.md CURLINFO_FILETIME.md CURLINFO_FILETIME_T.md CURLINFO_FTP_ENTRY_PATH.md CURLINFO_HEADER_SIZE.md CURLINFO_HTTPAUTH_AVAIL.md CURLINFO_HTTPAUTH_USED.md CURLINFO_HTTP_CONNECTCODE.md CURLINFO_HTTP_VERSION.md CURLINFO_LASTSOCKET.md CURLINFO_LOCAL_IP.md CURLINFO_LOCAL_PORT.md CURLINFO_NAMELOOKUP_TIME.md CURLINFO_NAMELOOKUP_TIME_T.md CURLINFO_NUM_CONNECTS.md CURLINFO_OS_ERRNO.md CURLINFO_POSTTRANSFER_TIME_T.md CURLINFO_PRETRANSFER_TIME.md CURLINFO_PRETRANSFER_TIME_T.md CURLINFO_PRIMARY_IP.md CURLINFO_PRIMARY_PORT.md CURLINFO_PRIVATE.md CURLINFO_PROTOCOL.md CURLINFO_PROXYAUTH_AVAIL.md CURLINFO_PROXYAUTH_USED.md CURLINFO_PROXY_ERROR.md CURLINFO_PROXY_SSL_VERIFYRESULT.md CURLINFO_QUEUE_TIME_T.md CURLINFO_REDIRECT_COUNT.md CURLINFO_REDIRECT_TIME.md CURLINFO_REDIRECT_TIME_T.md CURLINFO_REDIRECT_URL.md CURLINFO_REFERER.md CURLINFO_REQUEST_SIZE.md CURLINFO_RESPONSE_CODE.md CURLINFO_RETRY_AFTER.md CURLINFO_RTSP_CLIENT_CSEQ.md CURLINFO_RTSP_CSEQ_RECV.md CURLINFO_RTSP_SERVER_CSEQ.md CURLINFO_RTSP_SESSION_ID.md CURLINFO_SCHEME.md CURLINFO_SIZE_DELIVERED.md CURLINFO_SIZE_DOWNLOAD.md CURLINFO_SIZE_DOWNLOAD_T.md CURLINFO_SIZE_UPLOAD.md CURLINFO_SIZE_UPLOAD_T.md CURLINFO_SPEED_DOWNLOAD.md CURLINFO_SPEED_DOWNLOAD_T.md CURLINFO_SPEED_UPLOAD.md CURLINFO_SPEED_UPLOAD_T.md CURLINFO_SSL_ENGINES.md CURLINFO_SSL_VERIFYRESULT.md CURLINFO_STARTTRANSFER_TIME.md CURLINFO_STARTTRANSFER_TIME_T.md CURLINFO_TLS_SESSION.md CURLINFO_TLS_SSL_PTR.md CURLINFO_TOTAL_TIME.md CURLINFO_TOTAL_TIME_T.md CURLINFO_USED_PROXY.md CURLINFO_XFER_ID.md CURLMINFO_XFERS_ADDED.md CURLMINFO_XFERS_CURRENT.md CURLMINFO_XFERS_DONE.md CURLMINFO_XFERS_PENDING.md CURLMINFO_XFERS_RUNNING.md CURLMOPT_CHUNK_LENGTH_PENALTY_SIZE.md CURLMOPT_CONTENT_LENGTH_PENALTY_SIZE.md CURLMOPT_MAXCONNECTS.md CURLMOPT_MAX_CONCURRENT_STREAMS.md CURLMOPT_MAX_HOST_CONNECTIONS.md CURLMOPT_MAX_PIPELINE_LENGTH.md CURLMOPT_MAX_TOTAL_CONNECTIONS.md CURLMOPT_NETWORK_CHANGED.md CURLMOPT_NOTIFYDATA.md CURLMOPT_NOTIFYFUNCTION.md CURLMOPT_PIPELINING.md CURLMOPT_PIPELINING_SERVER_BL.md CURLMOPT_PIPELINING_SITE_BL.md CURLMOPT_PUSHDATA.md CURLMOPT_PUSHFUNCTION.md CURLMOPT_QUICK_EXIT.md CURLMOPT_RESOLVE_THREADS_MAX.md CURLMOPT_SOCKETDATA.md CURLMOPT_SOCKETFUNCTION.md CURLMOPT_TIMERDATA.md CURLMOPT_TIMERFUNCTION.md CURLOPT_ABSTRACT_UNIX_SOCKET.md CURLOPT_ACCEPTTIMEOUT_MS.md CURLOPT_ACCEPT_ENCODING.md CURLOPT_ADDRESS_SCOPE.md CURLOPT_ALTSVC.md CURLOPT_ALTSVC_CTRL.md CURLOPT_APPEND.md CURLOPT_AUTOREFERER.md CURLOPT_AWS_SIGV4.md CURLOPT_BUFFERSIZE.md CURLOPT_CAINFO.md CURLOPT_CAINFO_BLOB.md CURLOPT_CAPATH.md CURLOPT_CA_CACHE_TIMEOUT.md CURLOPT_CERTINFO.md CURLOPT_CHUNK_BGN_FUNCTION.md CURLOPT_CHUNK_DATA.md CURLOPT_CHUNK_END_FUNCTION.md CURLOPT_CLOSESOCKETDATA.md CURLOPT_CLOSESOCKETFUNCTION.md CURLOPT_CONNECTTIMEOUT.md CURLOPT_CONNECTTIMEOUT_MS.md CURLOPT_CONNECT_ONLY.md CURLOPT_CONNECT_TO.md CURLOPT_CONV_FROM_NETWORK_FUNCTION.md CURLOPT_CONV_FROM_UTF8_FUNCTION.md CURLOPT_CONV_TO_NETWORK_FUNCTION.md CURLOPT_COOKIE.md CURLOPT_COOKIEFILE.md CURLOPT_COOKIEJAR.md CURLOPT_COOKIELIST.md CURLOPT_COOKIESESSION.md CURLOPT_COPYPOSTFIELDS.md CURLOPT_CRLF.md CURLOPT_CRLFILE.md CURLOPT_CURLU.md CURLOPT_CUSTOMREQUEST.md CURLOPT_DEBUGDATA.md CURLOPT_DEBUGFUNCTION.md CURLOPT_DEFAULT_PROTOCOL.md CURLOPT_DIRLISTONLY.md CURLOPT_DISALLOW_USERNAME_IN_URL.md CURLOPT_DNS_CACHE_TIMEOUT.md CURLOPT_DNS_INTERFACE.md CURLOPT_DNS_LOCAL_IP4.md CURLOPT_DNS_LOCAL_IP6.md CURLOPT_DNS_SERVERS.md CURLOPT_DNS_SHUFFLE_ADDRESSES.md CURLOPT_DNS_USE_GLOBAL_CACHE.md CURLOPT_DOH_SSL_VERIFYHOST.md CURLOPT_DOH_SSL_VERIFYPEER.md CURLOPT_DOH_SSL_VERIFYSTATUS.md CURLOPT_DOH_URL.md CURLOPT_ECH.md CURLOPT_EGDSOCKET.md CURLOPT_ERRORBUFFER.md CURLOPT_EXPECT_100_TIMEOUT_MS.md CURLOPT_FAILONERROR.md CURLOPT_FILETIME.md CURLOPT_FNMATCH_DATA.md CURLOPT_FNMATCH_FUNCTION.md CURLOPT_FOLLOWLOCATION.md CURLOPT_FORBID_REUSE.md CURLOPT_FRESH_CONNECT.md CURLOPT_FTPPORT.md CURLOPT_FTPSSLAUTH.md CURLOPT_FTP_ACCOUNT.md CURLOPT_FTP_ALTERNATIVE_TO_USER.md CURLOPT_FTP_CREATE_MISSING_DIRS.md CURLOPT_FTP_FILEMETHOD.md CURLOPT_FTP_SKIP_PASV_IP.md CURLOPT_FTP_SSL_CCC.md CURLOPT_FTP_USE_EPRT.md CURLOPT_FTP_USE_EPSV.md CURLOPT_FTP_USE_PRET.md CURLOPT_GSSAPI_DELEGATION.md CURLOPT_HAPPY_EYEBALLS_TIMEOUT_MS.md CURLOPT_HAPROXYPROTOCOL.md CURLOPT_HAPROXY_CLIENT_IP.md CURLOPT_HEADER.md CURLOPT_HEADERDATA.md CURLOPT_HEADERFUNCTION.md CURLOPT_HEADEROPT.md CURLOPT_HSTS.md CURLOPT_HSTSREADDATA.md CURLOPT_HSTSREADFUNCTION.md CURLOPT_HSTSWRITEDATA.md CURLOPT_HSTSWRITEFUNCTION.md CURLOPT_HSTS_CTRL.md CURLOPT_HTTP09_ALLOWED.md CURLOPT_HTTP200ALIASES.md CURLOPT_HTTPAUTH.md CURLOPT_HTTPGET.md CURLOPT_HTTPHEADER.md CURLOPT_HTTPPOST.md CURLOPT_HTTPPROXYTUNNEL.md CURLOPT_HTTP_CONTENT_DECODING.md CURLOPT_HTTP_TRANSFER_DECODING.md CURLOPT_HTTP_VERSION.md CURLOPT_IGNORE_CONTENT_LENGTH.md CURLOPT_INFILESIZE.md CURLOPT_INFILESIZE_LARGE.md CURLOPT_INTERFACE.md CURLOPT_INTERLEAVEDATA.md CURLOPT_INTERLEAVEFUNCTION.md CURLOPT_IOCTLDATA.md CURLOPT_IOCTLFUNCTION.md CURLOPT_IPRESOLVE.md CURLOPT_ISSUERCERT.md CURLOPT_ISSUERCERT_BLOB.md CURLOPT_KEEP_SENDING_ON_ERROR.md CURLOPT_KEYPASSWD.md CURLOPT_KRBLEVEL.md CURLOPT_LOCALPORT.md CURLOPT_LOCALPORTRANGE.md CURLOPT_LOGIN_OPTIONS.md CURLOPT_LOW_SPEED_LIMIT.md CURLOPT_LOW_SPEED_TIME.md CURLOPT_MAIL_AUTH.md CURLOPT_MAIL_FROM.md CURLOPT_MAIL_RCPT.md CURLOPT_MAIL_RCPT_ALLOWFAILS.md CURLOPT_MAXAGE_CONN.md CURLOPT_MAXCONNECTS.md CURLOPT_MAXFILESIZE.md CURLOPT_MAXFILESIZE_LARGE.md CURLOPT_MAXLIFETIME_CONN.md CURLOPT_MAXREDIRS.md CURLOPT_MAX_RECV_SPEED_LARGE.md CURLOPT_MAX_SEND_SPEED_LARGE.md CURLOPT_MIMEPOST.md CURLOPT_MIME_OPTIONS.md CURLOPT_NETRC.md CURLOPT_NETRC_FILE.md CURLOPT_NEW_DIRECTORY_PERMS.md CURLOPT_NEW_FILE_PERMS.md CURLOPT_NOBODY.md CURLOPT_NOPROGRESS.md CURLOPT_NOPROXY.md CURLOPT_NOSIGNAL.md CURLOPT_OPENSOCKETDATA.md CURLOPT_OPENSOCKETFUNCTION.md CURLOPT_PASSWORD.md CURLOPT_PATH_AS_IS.md CURLOPT_PINNEDPUBLICKEY.md CURLOPT_PIPEWAIT.md CURLOPT_PORT.md CURLOPT_POST.md CURLOPT_POSTFIELDS.md CURLOPT_POSTFIELDSIZE.md CURLOPT_POSTFIELDSIZE_LARGE.md CURLOPT_POSTQUOTE.md CURLOPT_POSTREDIR.md CURLOPT_PREQUOTE.md CURLOPT_PREREQDATA.md CURLOPT_PREREQFUNCTION.md CURLOPT_PRE_PROXY.md CURLOPT_PRIVATE.md CURLOPT_PROGRESSDATA.md CURLOPT_PROGRESSFUNCTION.md CURLOPT_PROTOCOLS.md CURLOPT_PROTOCOLS_STR.md CURLOPT_PROXY.md CURLOPT_PROXYAUTH.md CURLOPT_PROXYHEADER.md CURLOPT_PROXYPASSWORD.md CURLOPT_PROXYPORT.md CURLOPT_PROXYTYPE.md CURLOPT_PROXYUSERNAME.md CURLOPT_PROXYUSERPWD.md CURLOPT_PROXY_CAINFO.md CURLOPT_PROXY_CAINFO_BLOB.md CURLOPT_PROXY_CAPATH.md CURLOPT_PROXY_CRLFILE.md CURLOPT_PROXY_ISSUERCERT.md CURLOPT_PROXY_ISSUERCERT_BLOB.md CURLOPT_PROXY_KEYPASSWD.md CURLOPT_PROXY_PINNEDPUBLICKEY.md CURLOPT_PROXY_SERVICE_NAME.md CURLOPT_PROXY_SSLCERT.md CURLOPT_PROXY_SSLCERTTYPE.md CURLOPT_PROXY_SSLCERT_BLOB.md CURLOPT_PROXY_SSLKEY.md CURLOPT_PROXY_SSLKEYTYPE.md CURLOPT_PROXY_SSLKEY_BLOB.md CURLOPT_PROXY_SSLVERSION.md CURLOPT_PROXY_SSL_CIPHER_LIST.md CURLOPT_PROXY_SSL_OPTIONS.md CURLOPT_PROXY_SSL_VERIFYHOST.md CURLOPT_PROXY_SSL_VERIFYPEER.md CURLOPT_PROXY_TLS13_CIPHERS.md CURLOPT_PROXY_TLSAUTH_PASSWORD.md CURLOPT_PROXY_TLSAUTH_TYPE.md CURLOPT_PROXY_TLSAUTH_USERNAME.md CURLOPT_PROXY_TRANSFER_MODE.md CURLOPT_PUT.md CURLOPT_QUICK_EXIT.md CURLOPT_QUOTE.md CURLOPT_RANDOM_FILE.md CURLOPT_RANGE.md CURLOPT_READDATA.md CURLOPT_READFUNCTION.md CURLOPT_REDIR_PROTOCOLS.md CURLOPT_REDIR_PROTOCOLS_STR.md CURLOPT_REFERER.md CURLOPT_REQUEST_TARGET.md CURLOPT_RESOLVE.md CURLOPT_RESOLVER_START_DATA.md CURLOPT_RESOLVER_START_FUNCTION.md CURLOPT_RESUME_FROM.md CURLOPT_RESUME_FROM_LARGE.md CURLOPT_RTSP_CLIENT_CSEQ.md CURLOPT_RTSP_REQUEST.md CURLOPT_RTSP_SERVER_CSEQ.md CURLOPT_RTSP_SESSION_ID.md CURLOPT_RTSP_STREAM_URI.md CURLOPT_RTSP_TRANSPORT.md CURLOPT_SASL_AUTHZID.md CURLOPT_SASL_IR.md CURLOPT_SEEKDATA.md CURLOPT_SEEKFUNCTION.md CURLOPT_SERVER_RESPONSE_TIMEOUT.md CURLOPT_SERVER_RESPONSE_TIMEOUT_MS.md CURLOPT_SERVICE_NAME.md CURLOPT_SHARE.md CURLOPT_SOCKOPTDATA.md CURLOPT_SOCKOPTFUNCTION.md CURLOPT_SOCKS5_AUTH.md CURLOPT_SOCKS5_GSSAPI_NEC.md CURLOPT_SOCKS5_GSSAPI_SERVICE.md CURLOPT_SSH_AUTH_TYPES.md CURLOPT_SSH_COMPRESSION.md CURLOPT_SSH_HOSTKEYDATA.md CURLOPT_SSH_HOSTKEYFUNCTION.md CURLOPT_SSH_HOST_PUBLIC_KEY_MD5.md CURLOPT_SSH_HOST_PUBLIC_KEY_SHA256.md CURLOPT_SSH_KEYDATA.md CURLOPT_SSH_KEYFUNCTION.md CURLOPT_SSH_KNOWNHOSTS.md CURLOPT_SSH_PRIVATE_KEYFILE.md CURLOPT_SSH_PUBLIC_KEYFILE.md CURLOPT_SSLCERT.md CURLOPT_SSLCERTTYPE.md CURLOPT_SSLCERT_BLOB.md CURLOPT_SSLENGINE.md CURLOPT_SSLENGINE_DEFAULT.md CURLOPT_SSLKEY.md CURLOPT_SSLKEYTYPE.md CURLOPT_SSLKEY_BLOB.md CURLOPT_SSLVERSION.md CURLOPT_SSL_CIPHER_LIST.md CURLOPT_SSL_CTX_DATA.md CURLOPT_SSL_CTX_FUNCTION.md CURLOPT_SSL_EC_CURVES.md CURLOPT_SSL_ENABLE_ALPN.md CURLOPT_SSL_ENABLE_NPN.md CURLOPT_SSL_FALSESTART.md CURLOPT_SSL_OPTIONS.md CURLOPT_SSL_SESSIONID_CACHE.md CURLOPT_SSL_SIGNATURE_ALGORITHMS.md CURLOPT_SSL_VERIFYHOST.md CURLOPT_SSL_VERIFYPEER.md CURLOPT_SSL_VERIFYSTATUS.md CURLOPT_STDERR.md CURLOPT_STREAM_DEPENDS.md CURLOPT_STREAM_DEPENDS_E.md CURLOPT_STREAM_WEIGHT.md CURLOPT_SUPPRESS_CONNECT_HEADERS.md CURLOPT_TCP_FASTOPEN.md CURLOPT_TCP_KEEPALIVE.md CURLOPT_TCP_KEEPCNT.md CURLOPT_TCP_KEEPIDLE.md CURLOPT_TCP_KEEPINTVL.md CURLOPT_TCP_NODELAY.md CURLOPT_TELNETOPTIONS.md CURLOPT_TFTP_BLKSIZE.md CURLOPT_TFTP_NO_OPTIONS.md CURLOPT_TIMECONDITION.md CURLOPT_TIMEOUT.md CURLOPT_TIMEOUT_MS.md CURLOPT_TIMEVALUE.md CURLOPT_TIMEVALUE_LARGE.md CURLOPT_TLS13_CIPHERS.md CURLOPT_TLSAUTH_PASSWORD.md CURLOPT_TLSAUTH_TYPE.md CURLOPT_TLSAUTH_USERNAME.md CURLOPT_TRAILERDATA.md CURLOPT_TRAILERFUNCTION.md CURLOPT_TRANSFERTEXT.md CURLOPT_TRANSFER_ENCODING.md CURLOPT_UNIX_SOCKET_PATH.md CURLOPT_UNRESTRICTED_AUTH.md CURLOPT_UPKEEP_INTERVAL_MS.md CURLOPT_UPLOAD.md CURLOPT_UPLOAD_BUFFERSIZE.md CURLOPT_UPLOAD_FLAGS.md CURLOPT_URL.md CURLOPT_USERAGENT.md CURLOPT_USERNAME.md CURLOPT_USERPWD.md CURLOPT_USE_SSL.md CURLOPT_VERBOSE.md CURLOPT_WILDCARDMATCH.md CURLOPT_WRITEDATA.md CURLOPT_WRITEFUNCTION.md CURLOPT_WS_OPTIONS.md CURLOPT_XFERINFODATA.md CURLOPT_XFERINFOFUNCTION.md CURLOPT_XOAUTH2_BEARER.md CURLSHOPT_LOCKFUNC.md CURLSHOPT_SHARE.md CURLSHOPT_UNLOCKFUNC.md CURLSHOPT_UNSHARE.md CURLSHOPT_USERDATA.md Makefile.am Makefile.incinclude
curl
Makefile.am curl.h curlver.h easy.h header.h mprintf.h multi.h options.h stdcheaders.h system.h typecheck-gcc.h urlapi.h websockets.hlib
curlx
base64.c base64.h basename.c basename.h dynbuf.c dynbuf.h fopen.c fopen.h inet_ntop.c inet_ntop.h inet_pton.c inet_pton.h multibyte.c multibyte.h nonblock.c nonblock.h snprintf.c snprintf.h strcopy.c strcopy.h strdup.c strdup.h strerr.c strerr.h strparse.c strparse.h timediff.c timediff.h timeval.c timeval.h version_win32.c version_win32.h wait.c wait.h warnless.c warnless.h winapi.c winapi.hvauth
cleartext.c cram.c digest.c digest.h digest_sspi.c gsasl.c krb5_gssapi.c krb5_sspi.c ntlm.c ntlm_sspi.c oauth2.c spnego_gssapi.c spnego_sspi.c vauth.c vauth.hvquic
curl_ngtcp2.c curl_ngtcp2.h curl_quiche.c curl_quiche.h vquic-tls.c vquic-tls.h vquic.c vquic.h vquic_int.hvtls
apple.c apple.h cipher_suite.c cipher_suite.h gtls.c gtls.h hostcheck.c hostcheck.h keylog.c keylog.h mbedtls.c mbedtls.h openssl.c openssl.h rustls.c rustls.h schannel.c schannel.h schannel_int.h schannel_verify.c vtls.c vtls.h vtls_int.h vtls_scache.c vtls_scache.h vtls_spack.c vtls_spack.h wolfssl.c wolfssl.h x509asn1.c x509asn1.hm4
.gitignore curl-amissl.m4 curl-apple-sectrust.m4 curl-compilers.m4 curl-confopts.m4 curl-functions.m4 curl-gnutls.m4 curl-mbedtls.m4 curl-openssl.m4 curl-override.m4 curl-reentrant.m4 curl-rustls.m4 curl-schannel.m4 curl-sysconfig.m4 curl-wolfssl.m4 xc-am-iface.m4 xc-cc-check.m4 xc-lt-iface.m4 xc-val-flgs.m4 zz40-xc-ovr.m4 zz50-xc-ovr.m4projects
OS400
.checksrc README.OS400 ccsidcurl.c ccsidcurl.h config400.default curl.cmd curl.inc.in curlcl.c curlmain.c initscript.sh make-docs.sh make-include.sh make-lib.sh make-src.sh make-tests.sh makefile.sh os400sys.c os400sys.hWindows
tmpl
.gitattributes README.txt curl-all.sln curl.sln curl.vcxproj curl.vcxproj.filters libcurl.sln libcurl.vcxproj libcurl.vcxproj.filtersvms
Makefile.am backup_gnv_curl_src.com build_curl-config_script.com build_gnv_curl.com build_gnv_curl_pcsi_desc.com build_gnv_curl_pcsi_text.com build_gnv_curl_release_notes.com build_libcurl_pc.com build_vms.com clean_gnv_curl.com compare_curl_source.com config_h.com curl_crtl_init.c curl_gnv_build_steps.txt curl_release_note_start.txt curl_startup.com curlmsg.h curlmsg.msg curlmsg.sdl curlmsg_vms.h generate_config_vms_h_curl.com generate_vax_transfer.com gnv_conftest.c_first gnv_curl_configure.sh gnv_libcurl_symbols.opt gnv_link_curl.com macro32_exactcase.patch make_gnv_curl_install.sh make_pcsi_curl_kit_name.com pcsi_gnv_curl_file_list.txt pcsi_product_gnv_curl.com readme report_openssl_version.c setup_gnv_curl_build.com stage_curl_install.com vms_eco_level.hscripts
.checksrc CMakeLists.txt Makefile.am badwords badwords-all badwords.txt cd2cd cd2nroff cdall checksrc-all.pl checksrc.pl cmakelint.sh completion.pl contributors.sh contrithanks.sh coverage.sh delta dmaketgz extract-unit-protos firefox-db2pem.sh installcheck.sh maketgz managen mdlinkcheck mk-ca-bundle.pl mk-unity.pl nroff2cd perlcheck.sh pythonlint.sh randdisable release-notes.pl release-tools.sh schemetable.c singleuse.pl spacecheck.pl top-complexity top-length verify-release wcurlsrc
.checksrc .gitignore CMakeLists.txt Makefile.am Makefile.inc config2setopts.c config2setopts.h curl.rc curlinfo.c mk-file-embed.pl mkhelp.pl slist_wc.c slist_wc.h terminal.c terminal.h tool_cb_dbg.c tool_cb_dbg.h tool_cb_hdr.c tool_cb_hdr.h tool_cb_prg.c tool_cb_prg.h tool_cb_rea.c tool_cb_rea.h tool_cb_see.c tool_cb_see.h tool_cb_soc.c tool_cb_soc.h tool_cb_wrt.c tool_cb_wrt.h tool_cfgable.c tool_cfgable.h tool_dirhie.c tool_dirhie.h tool_doswin.c tool_doswin.h tool_easysrc.c tool_easysrc.h tool_filetime.c tool_filetime.h tool_findfile.c tool_findfile.h tool_formparse.c tool_formparse.h tool_getparam.c tool_getparam.h tool_getpass.c tool_getpass.h tool_help.c tool_help.h tool_helpers.c tool_helpers.h tool_hugehelp.h tool_ipfs.c tool_ipfs.h tool_libinfo.c tool_libinfo.h tool_listhelp.c tool_main.c tool_main.h tool_msgs.c tool_msgs.h tool_operate.c tool_operate.h tool_operhlp.c tool_operhlp.h tool_paramhlp.c tool_paramhlp.h tool_parsecfg.c tool_parsecfg.h tool_progress.c tool_progress.h tool_sdecls.h tool_setopt.c tool_setopt.h tool_setup.h tool_ssls.c tool_ssls.h tool_stderr.c tool_stderr.h tool_urlglob.c tool_urlglob.h tool_util.c tool_util.h tool_version.h tool_vms.c tool_vms.h tool_writeout.c tool_writeout.h tool_writeout_json.c tool_writeout_json.h tool_xattr.c tool_xattr.h var.c var.htests
certs
.gitignore CMakeLists.txt Makefile.am Makefile.inc genserv.pl srp-verifier-conf srp-verifier-db test-ca.cnf test-ca.prm test-client-cert.prm test-client-eku-only.prm test-localhost-san-first.prm test-localhost-san-last.prm test-localhost.nn.prm test-localhost.prm test-localhost0h.prmdata
.gitignore DISABLED Makefile.am data-xml1 data1400.c data1401.c data1402.c data1403.c data1404.c data1405.c data1406.c data1407.c data1420.c data1461.txt data1463.txt data1465.c data1481.c data1705-1.md data1705-2.md data1705-3.md data1705-4.md data1705-stdout.1 data1706-1.md data1706-2.md data1706-3.md data1706-4.md data1706-stdout.txt data320.html test1 test10 test100 test1000 test1001 test1002 test1003 test1004 test1005 test1006 test1007 test1008 test1009 test101 test1010 test1011 test1012 test1013 test1014 test1015 test1016 test1017 test1018 test1019 test102 test1020 test1021 test1022 test1023 test1024 test1025 test1026 test1027 test1028 test1029 test103 test1030 test1031 test1032 test1033 test1034 test1035 test1036 test1037 test1038 test1039 test104 test1040 test1041 test1042 test1043 test1044 test1045 test1046 test1047 test1048 test1049 test105 test1050 test1051 test1052 test1053 test1054 test1055 test1056 test1057 test1058 test1059 test106 test1060 test1061 test1062 test1063 test1064 test1065 test1066 test1067 test1068 test1069 test107 test1070 test1071 test1072 test1073 test1074 test1075 test1076 test1077 test1078 test1079 test108 test1080 test1081 test1082 test1083 test1084 test1085 test1086 test1087 test1088 test1089 test109 test1090 test1091 test1092 test1093 test1094 test1095 test1096 test1097 test1098 test1099 test11 test110 test1100 test1101 test1102 test1103 test1104 test1105 test1106 test1107 test1108 test1109 test111 test1110 test1111 test1112 test1113 test1114 test1115 test1116 test1117 test1118 test1119 test112 test1120 test1121 test1122 test1123 test1124 test1125 test1126 test1127 test1128 test1129 test113 test1130 test1131 test1132 test1133 test1134 test1135 test1136 test1137 test1138 test1139 test114 test1140 test1141 test1142 test1143 test1144 test1145 test1146 test1147 test1148 test1149 test115 test1150 test1151 test1152 test1153 test1154 test1155 test1156 test1157 test1158 test1159 test116 test1160 test1161 test1162 test1163 test1164 test1165 test1166 test1167 test1168 test1169 test117 test1170 test1171 test1172 test1173 test1174 test1175 test1176 test1177 test1178 test1179 test118 test1180 test1181 test1182 test1183 test1184 test1185 test1186 test1187 test1188 test1189 test119 test1190 test1191 test1192 test1193 test1194 test1195 test1196 test1197 test1198 test1199 test12 test120 test1200 test1201 test1202 test1203 test1204 test1205 test1206 test1207 test1208 test1209 test121 test1210 test1211 test1212 test1213 test1214 test1215 test1216 test1217 test1218 test1219 test122 test1220 test1221 test1222 test1223 test1224 test1225 test1226 test1227 test1228 test1229 test123 test1230 test1231 test1232 test1233 test1234 test1235 test1236 test1237 test1238 test1239 test124 test1240 test1241 test1242 test1243 test1244 test1245 test1246 test1247 test1248 test1249 test125 test1250 test1251 test1252 test1253 test1254 test1255 test1256 test1257 test1258 test1259 test126 test1260 test1261 test1262 test1263 test1264 test1265 test1266 test1267 test1268 test1269 test127 test1270 test1271 test1272 test1273 test1274 test1275 test1276 test1277 test1278 test1279 test128 test1280 test1281 test1282 test1283 test1284 test1285 test1286 test1287 test1288 test1289 test129 test1290 test1291 test1292 test1293 test1294 test1295 test1296 test1297 test1298 test1299 test13 test130 test1300 test1301 test1302 test1303 test1304 test1305 test1306 test1307 test1308 test1309 test131 test1310 test1311 test1312 test1313 test1314 test1315 test1316 test1317 test1318 test1319 test132 test1320 test1321 test1322 test1323 test1324 test1325 test1326 test1327 test1328 test1329 test133 test1330 test1331 test1332 test1333 test1334 test1335 test1336 test1337 test1338 test1339 test134 test1340 test1341 test1342 test1343 test1344 test1345 test1346 test1347 test1348 test1349 test135 test1350 test1351 test1352 test1353 test1354 test1355 test1356 test1357 test1358 test1359 test136 test1360 test1361 test1362 test1363 test1364 test1365 test1366 test1367 test1368 test1369 test137 test1370 test1371 test1372 test1373 test1374 test1375 test1376 test1377 test1378 test1379 test138 test1380 test1381 test1382 test1383 test1384 test1385 test1386 test1387 test1388 test1389 test139 test1390 test1391 test1392 test1393 test1394 test1395 test1396 test1397 test1398 test1399 test14 test140 test1400 test1401 test1402 test1403 test1404 test1405 test1406 test1407 test1408 test1409 test141 test1410 test1411 test1412 test1413 test1414 test1415 test1416 test1417 test1418 test1419 test142 test1420 test1421 test1422 test1423 test1424 test1425 test1426 test1427 test1428 test1429 test143 test1430 test1431 test1432 test1433 test1434 test1435 test1436 test1437 test1438 test1439 test144 test1440 test1441 test1442 test1443 test1444 test1445 test1446 test1447 test1448 test1449 test145 test1450 test1451 test1452 test1453 test1454 test1455 test1456 test1457 test1458 test1459 test146 test1460 test1461 test1462 test1463 test1464 test1465 test1466 test1467 test1468 test1469 test147 test1470 test1471 test1472 test1473 test1474 test1475 test1476 test1477 test1478 test1479 test148 test1480 test1481 test1482 test1483 test1484 test1485 test1486 test1487 test1488 test1489 test149 test1490 test1491 test1492 test1493 test1494 test1495 test1496 test1497 test1498 test1499 test15 test150 test1500 test1501 test1502 test1503 test1504 test1505 test1506 test1507 test1508 test1509 test151 test1510 test1511 test1512 test1513 test1514 test1515 test1516 test1517 test1518 test1519 test152 test1520 test1521 test1522 test1523 test1524 test1525 test1526 test1527 test1528 test1529 test153 test1530 test1531 test1532 test1533 test1534 test1535 test1536 test1537 test1538 test1539 test154 test1540 test1541 test1542 test1543 test1544 test1545 test1546 test1547 test1548 test1549 test155 test1550 test1551 test1552 test1553 test1554 test1555 test1556 test1557 test1558 test1559 test156 test1560 test1561 test1562 test1563 test1564 test1565 test1566 test1567 test1568 test1569 test157 test1570 test1571 test1572 test1573 test1574 test1575 test1576 test1577 test1578 test1579 test158 test1580 test1581 test1582 test1583 test1584 test1585 test1586 test1587 test1588 test1589 test159 test1590 test1591 test1592 test1593 test1594 test1595 test1596 test1597 test1598 test1599 test16 test160 test1600 test1601 test1602 test1603 test1604 test1605 test1606 test1607 test1608 test1609 test161 test1610 test1611 test1612 test1613 test1614 test1615 test1616 test1617 test1618 test1619 test162 test1620 test1621 test1622 test1623 test1624 test1625 test1626 test1627 test1628 test1629 test163 test1630 test1631 test1632 test1633 test1634 test1635 test1636 test1637 test1638 test1639 test164 test1640 test1641 test1642 test1643 test1644 test1645 test165 test1650 test1651 test1652 test1653 test1654 test1655 test1656 test1657 test1658 test1659 test166 test1660 test1661 test1662 test1663 test1664 test1665 test1666 test1667 test1668 test1669 test167 test1670 test1671 test1672 test1673 test1674 test1675 test1676 test168 test1680 test1681 test1682 test1683 test1684 test1685 test169 test17 test170 test1700 test1701 test1702 test1703 test1704 test1705 test1706 test1707 test1708 test1709 test171 test1710 test1711 test1712 test1713 test1714 test1715 test172 test1720 test1721 test173 test174 test175 test176 test177 test178 test179 test18 test180 test1800 test1801 test1802 test181 test182 test183 test184 test1847 test1848 test1849 test185 test1850 test1851 test186 test187 test188 test189 test19 test190 test1900 test1901 test1902 test1903 test1904 test1905 test1906 test1907 test1908 test1909 test191 test1910 test1911 test1912 test1913 test1914 test1915 test1916 test1917 test1918 test1919 test192 test1920 test1921 test193 test1933 test1934 test1935 test1936 test1937 test1938 test1939 test194 test1940 test1941 test1942 test1943 test1944 test1945 test1946 test1947 test1948 test195 test1955 test1956 test1957 test1958 test1959 test196 test1960 test1964 test1965 test1966 test197 test1970 test1971 test1972 test1973 test1974 test1975 test1976 test1977 test1978 test1979 test198 test1980 test1981 test1982 test1983 test1984 test199 test2 test20 test200 test2000 test2001 test2002 test2003 test2004 test2005 test2006 test2007 test2008 test2009 test201 test2010 test2011 test2012 test2013 test2014 test202 test2023 test2024 test2025 test2026 test2027 test2028 test2029 test203 test2030 test2031 test2032 test2033 test2034 test2035 test2037 test2038 test2039 test204 test2040 test2041 test2042 test2043 test2044 test2045 test2046 test2047 test2048 test2049 test205 test2050 test2051 test2052 test2053 test2054 test2055 test2056 test2057 test2058 test2059 test206 test2060 test2061 test2062 test2063 test2064 test2065 test2066 test2067 test2068 test2069 test207 test2070 test2071 test2072 test2073 test2074 test2075 test2076 test2077 test2078 test2079 test208 test2080 test2081 test2082 test2083 test2084 test2085 test2086 test2087 test2088 test2089 test209 test2090 test2091 test2092 test21 test210 test2100 test2101 test2102 test2103 test2104 test211 test212 test213 test214 test215 test216 test217 test218 test219 test22 test220 test2200 test2201 test2202 test2203 test2204 test2205 test2206 test2207 test221 test222 test223 test224 test225 test226 test227 test228 test229 test23 test230 test2300 test2301 test2302 test2303 test2304 test2306 test2307 test2308 test2309 test231 test232 test233 test234 test235 test236 test237 test238 test239 test24 test240 test2400 test2401 test2402 test2403 test2404 test2405 test2406 test2407 test2408 test2409 test241 test2410 test2411 test242 test243 test244 test245 test246 test247 test248 test249 test25 test250 test2500 test2501 test2502 test2503 test2504 test2505 test2506 test251 test252 test253 test254 test255 test256 test257 test258 test259 test26 test260 test2600 test2601 test2602 test2603 test2604 test2605 test261 test262 test263 test264 test265 test266 test267 test268 test269 test27 test270 test2700 test2701 test2702 test2703 test2704 test2705 test2706 test2707 test2708 test2709 test271 test2710 test2711 test2712 test2713 test2714 test2715 test2716 test2717 test2718 test2719 test272 test2720 test2721 test2722 test2723 test273 test274 test275 test276 test277 test278 test279 test28 test280 test281 test282 test283 test284 test285 test286 test287 test288 test289 test29 test290 test291 test292 test293 test294 test295 test296 test297 test298 test299 test3 test30 test300 test3000 test3001 test3002 test3003 test3004 test3005 test3006 test3007 test3008 test3009 test301 test3010 test3011 test3012 test3013 test3014 test3015 test3016 test3017 test3018 test3019 test302 test3020 test3021 test3022 test3023 test3024 test3025 test3026 test3027 test3028 test3029 test303 test3030 test3031 test3032 test3033 test3034 test3035 test3036 test304 test305 test306 test307 test308 test309 test31 test310 test3100 test3101 test3102 test3103 test3104 test3105 test3106 test311 test312 test313 test314 test315 test316 test317 test318 test319 test32 test320 test3200 test3201 test3202 test3203 test3204 test3205 test3206 test3207 test3208 test3209 test321 test3210 test3211 test3212 test3213 test3214 test3215 test3216 test3217 test3218 test3219 test322 test3220 test323 test324 test325 test326 test327 test328 test329 test33 test330 test3300 test3301 test3302 test331 test332 test333 test334 test335 test336 test337 test338 test339 test34 test340 test341 test342 test343 test344 test345 test346 test347 test348 test349 test35 test350 test351 test352 test353 test354 test355 test356 test357 test358 test359 test36 test360 test361 test362 test363 test364 test365 test366 test367 test368 test369 test37 test370 test371 test372 test373 test374 test375 test376 test378 test379 test38 test380 test381 test383 test384 test385 test386 test387 test388 test389 test39 test390 test391 test392 test393 test394 test395 test396 test397 test398 test399 test4 test40 test400 test4000 test4001 test401 test402 test403 test404 test405 test406 test407 test408 test409 test41 test410 test411 test412 test413 test414 test415 test416 test417 test418 test419 test42 test420 test421 test422 test423 test424 test425 test426 test427 test428 test429 test43 test430 test431 test432 test433 test434 test435 test436 test437 test438 test439 test44 test440 test441 test442 test443 test444 test445 test446 test447 test448 test449 test45 test450 test451 test452 test453 test454 test455 test456 test457 test458 test459 test46 test460 test461 test462 test463 test467 test468 test469 test47 test470 test471 test472 test473 test474 test475 test476 test477 test478 test479 test48 test480 test481 test482 test483 test484 test485 test486 test487 test488 test489 test49 test490 test491 test492 test493 test494 test495 test496 test497 test498 test499 test5 test50 test500 test501 test502 test503 test504 test505 test506 test507 test508 test509 test51 test510 test511 test512 test513 test514 test515 test516 test517 test518 test519 test52 test520 test521 test522 test523 test524 test525 test526 test527 test528 test529 test53 test530 test531 test532 test533 test534 test535 test536 test537 test538 test539 test54 test540 test541 test542 test543 test544 test545 test546 test547 test548 test549 test55 test550 test551 test552 test553 test554 test555 test556 test557 test558 test559 test56 test560 test561 test562 test563 test564 test565 test566 test567 test568 test569 test57 test570 test571 test572 test573 test574 test575 test576 test577 test578 test579 test58 test580 test581 test582 test583 test584 test585 test586 test587 test588 test589 test59 test590 test591 test592 test593 test594 test595 test596 test597 test598 test599 test6 test60 test600 test601 test602 test603 test604 test605 test606 test607 test608 test609 test61 test610 test611 test612 test613 test614 test615 test616 test617 test618 test619 test62 test620 test621 test622 test623 test624 test625 test626 test627 test628 test629 test63 test630 test631 test632 test633 test634 test635 test636 test637 test638 test639 test64 test640 test641 test642 test643 test644 test645 test646 test647 test648 test649 test65 test650 test651 test652 test653 test654 test655 test656 test658 test659 test66 test660 test661 test662 test663 test664 test665 test666 test667 test668 test669 test67 test670 test671 test672 test673 test674 test675 test676 test677 test678 test679 test68 test680 test681 test682 test683 test684 test685 test686 test687 test688 test689 test69 test690 test691 test692 test693 test694 test695 test696 test697 test698 test699 test7 test70 test700 test701 test702 test703 test704 test705 test706 test707 test708 test709 test71 test710 test711 test712 test713 test714 test715 test716 test717 test718 test719 test72 test720 test721 test722 test723 test724 test725 test726 test727 test728 test729 test73 test730 test731 test732 test733 test734 test735 test736 test737 test738 test739 test74 test740 test741 test742 test743 test744 test745 test746 test747 test748 test749 test75 test750 test751 test752 test753 test754 test755 test756 test757 test758 test759 test76 test760 test761 test762 test763 test764 test765 test766 test767 test768 test769 test77 test770 test771 test772 test773 test774 test775 test776 test777 test778 test779 test78 test780 test781 test782 test783 test784 test785 test786 test787 test788 test789 test79 test790 test791 test792 test793 test794 test795 test796 test797 test798 test799 test8 test80 test800 test801 test802 test803 test804 test805 test806 test807 test808 test809 test81 test810 test811 test812 test813 test814 test815 test816 test817 test818 test819 test82 test820 test821 test822 test823 test824 test825 test826 test827 test828 test829 test83 test830 test831 test832 test833 test834 test835 test836 test837 test838 test839 test84 test840 test841 test842 test843 test844 test845 test846 test847 test848 test849 test85 test850 test851 test852 test853 test854 test855 test856 test857 test858 test859 test86 test860 test861 test862 test863 test864 test865 test866 test867 test868 test869 test87 test870 test871 test872 test873 test874 test875 test876 test877 test878 test879 test88 test880 test881 test882 test883 test884 test885 test886 test887 test888 test889 test89 test890 test891 test892 test893 test894 test895 test896 test897 test898 test899 test9 test90 test900 test901 test902 test903 test904 test905 test906 test907 test908 test909 test91 test910 test911 test912 test913 test914 test915 test916 test917 test918 test919 test92 test920 test921 test922 test923 test924 test925 test926 test927 test928 test929 test93 test930 test931 test932 test933 test934 test935 test936 test937 test938 test939 test94 test940 test941 test942 test943 test944 test945 test946 test947 test948 test949 test95 test950 test951 test952 test953 test954 test955 test956 test957 test958 test959 test96 test960 test961 test962 test963 test964 test965 test966 test967 test968 test969 test97 test970 test971 test972 test973 test974 test975 test976 test977 test978 test979 test98 test980 test981 test982 test983 test984 test985 test986 test987 test988 test989 test99 test990 test991 test992 test993 test994 test995 test996 test997 test998 test999http
testenv
__init__.py caddy.py certs.py client.py curl.py dante.py dnsd.py env.py httpd.py nghttpx.py ports.py sshd.py vsftpd.py ws_echo_server.pylibtest
.gitignore CMakeLists.txt Makefile.am Makefile.inc cli_ftp_upload.c cli_h2_pausing.c cli_h2_serverpush.c cli_h2_upgrade_extreme.c cli_hx_download.c cli_hx_upload.c cli_tls_session_reuse.c cli_upload_pausing.c cli_ws_data.c cli_ws_pingpong.c first.c first.h lib1156.c lib1301.c lib1308.c lib1485.c lib1500.c lib1501.c lib1502.c lib1506.c lib1507.c lib1508.c lib1509.c lib1510.c lib1511.c lib1512.c lib1513.c lib1514.c lib1515.c lib1517.c lib1518.c lib1520.c lib1522.c lib1523.c lib1525.c lib1526.c lib1527.c lib1528.c lib1529.c lib1530.c lib1531.c lib1532.c lib1533.c lib1534.c lib1535.c lib1536.c lib1537.c lib1538.c lib1540.c lib1541.c lib1542.c lib1545.c lib1549.c lib1550.c lib1551.c lib1552.c lib1553.c lib1554.c lib1555.c lib1556.c lib1557.c lib1558.c lib1559.c lib1560.c lib1564.c lib1565.c lib1567.c lib1568.c lib1569.c lib1571.c lib1576.c lib1582.c lib1587.c lib1588.c lib1589.c lib1591.c lib1592.c lib1593.c lib1594.c lib1597.c lib1598.c lib1599.c lib1662.c lib1900.c lib1901.c lib1902.c lib1903.c lib1905.c lib1906.c lib1907.c lib1908.c lib1910.c lib1911.c lib1912.c lib1913.c lib1915.c lib1916.c lib1918.c lib1919.c lib1920.c lib1921.c lib1933.c lib1934.c lib1935.c lib1936.c lib1937.c lib1938.c lib1939.c lib1940.c lib1945.c lib1947.c lib1948.c lib1955.c lib1956.c lib1957.c lib1958.c lib1959.c lib1960.c lib1964.c lib1965.c lib1970.c lib1971.c lib1972.c lib1973.c lib1974.c lib1975.c lib1977.c lib1978.c lib2023.c lib2032.c lib2082.c lib2301.c lib2302.c lib2304.c lib2306.c lib2308.c lib2309.c lib2402.c lib2404.c lib2405.c lib2502.c lib2504.c lib2505.c lib2506.c lib2700.c lib3010.c lib3025.c lib3026.c lib3027.c lib3033.c lib3034.c lib3100.c lib3101.c lib3102.c lib3103.c lib3104.c lib3105.c lib3207.c lib3208.c lib500.c lib501.c lib502.c lib503.c lib504.c lib505.c lib506.c lib507.c lib508.c lib509.c lib510.c lib511.c lib512.c lib513.c lib514.c lib515.c lib516.c lib517.c lib518.c lib519.c lib520.c lib521.c lib523.c lib524.c lib525.c lib526.c lib530.c lib533.c lib536.c lib537.c lib539.c lib540.c lib541.c lib542.c lib543.c lib544.c lib547.c lib549.c lib552.c lib553.c lib554.c lib555.c lib556.c lib557.c lib558.c lib559.c lib560.c lib562.c lib564.c lib566.c lib567.c lib568.c lib569.c lib570.c lib571.c lib572.c lib573.c lib574.c lib575.c lib576.c lib578.c lib579.c lib582.c lib583.c lib586.c lib589.c lib590.c lib591.c lib597.c lib598.c lib599.c lib643.c lib650.c lib651.c lib652.c lib653.c lib654.c lib655.c lib658.c lib659.c lib661.c lib666.c lib667.c lib668.c lib670.c lib674.c lib676.c lib677.c lib678.c lib694.c lib695.c lib751.c lib753.c lib757.c lib758.c lib766.c memptr.c mk-lib1521.pl test1013.pl test1022.pl test307.pl test610.pl test613.pl testtrace.c testtrace.h testutil.c testutil.h unitcheck.hserver
.checksrc .gitignore CMakeLists.txt Makefile.am Makefile.inc dnsd.c first.c first.h getpart.c mqttd.c resolve.c rtspd.c sockfilt.c socksd.c sws.c tftpd.c util.ctunit
.gitignore CMakeLists.txt Makefile.am Makefile.inc README.md tool1394.c tool1604.c tool1621.c tool1622.c tool1623.c tool1720.cunit
.gitignore CMakeLists.txt Makefile.am Makefile.inc README.md unit1300.c unit1302.c unit1303.c unit1304.c unit1305.c unit1307.c unit1309.c unit1323.c unit1330.c unit1395.c unit1396.c unit1397.c unit1398.c unit1399.c unit1600.c unit1601.c unit1602.c unit1603.c unit1605.c unit1606.c unit1607.c unit1608.c unit1609.c unit1610.c unit1611.c unit1612.c unit1614.c unit1615.c unit1616.c unit1620.c unit1625.c unit1626.c unit1627.c unit1636.c unit1650.c unit1651.c unit1652.c unit1653.c unit1654.c unit1655.c unit1656.c unit1657.c unit1658.c unit1660.c unit1661.c unit1663.c unit1664.c unit1666.c unit1667.c unit1668.c unit1669.c unit1674.c unit1675.c unit1676.c unit1979.c unit1980.c unit2600.c unit2601.c unit2602.c unit2603.c unit2604.c unit2605.c unit3200.c unit3205.c unit3211.c unit3212.c unit3213.c unit3214.c unit3216.c unit3219.c unit3300.c unit3301.c unit3302.cexamples
.env config.ini crypto_test.lua env_test.lua fs_example.lua http_server.lua https_test.lua ini_example.lua json.lua log.lua path_fs_example.lua process_example.lua request_download.lua request_test.lua run_all.lua sqlite_example.lua sqlite_http_template.lua stash_test.lua template_test.lua timer.lua websocket.luainiparser
example
iniexample.c iniwrite.c parse.c twisted-errors.ini twisted-genhuge.py twisted-ofkey.ini twisted-ofval.ini twisted.initest
CMakeLists.txt test_dictionary.c test_iniparser.c unity-config.yml unity_config.hjinjac
libjinjac
src
CMakeLists.txt ast.c ast.h block_statement.c block_statement.h buffer.c buffer.h buildin.c buildin.h common.h convert.c convert.h flex_decl.h jfunction.c jfunction.h jinja_expression.l jinja_expression.y jinjac_parse.c jinjac_parse.h jinjac_stream.c jinjac_stream.h jlist.c jlist.h jobject.c jobject.h parameter.c parameter.h str_obj.c str_obj.h trace.c trace.htest
.gitignore CMakeLists.txt autotest.rb test_01.expected test_01.jinja test_01b.expected test_01b.jinja test_01c.expected test_01c.jinja test_01d.expected test_01d.jinja test_02.expected test_02.jinja test_03.expected test_03.jinja test_04.expected test_04.jinja test_05.expected test_05.jinja test_06.expected test_06.jinja test_07.expected test_07.jinja test_08.expected test_08.jinja test_08b.expected test_08b.jinja test_09.expected test_09.jinja test_10.expected test_10.jinja test_11.expected test_11.jinja test_12.expected test_12.jinja test_13.expected test_13.jinja test_14.expected test_14.jinja test_15.expected test_15.jinja test_16.expected test_16.jinja test_17.expected test_17.jinja test_18.expected test_18.jinja test_18b.expected test_18b.jinja test_18c.expected test_18c.jinja test_19.expected test_19.jinja test_19b.expected test_19b.jinja test_19c.expected test_19c.jinja test_19d.expected test_19d.jinja test_19e.expected test_19e.jinja test_19f.expected test_19f.jinja test_20.expected test_20.jinja test_21.expected test_21.jinja test_22.expected test_22.jinja test_22a.expected test_22a.jinja test_22b.expected test_22b.jinja test_23.expected test_23.jinja test_24.expected test_24.jinjalibev
Changes LICENSE Makefile Makefile.am Makefile.in README Symbols.ev Symbols.event aclocal.m4 autogen.sh compile config.guess config.h config.h.in config.status config.sub configure configure.ac depcomp ev++.h ev.3 ev.c ev.h ev.pod ev_epoll.c ev_kqueue.c ev_poll.c ev_port.c ev_select.c ev_vars.h ev_win32.c ev_wrap.h event.c event.h install-sh libev.m4 libtool ltmain.sh missing mkinstalldirs stamp-h1luajit
doc
bluequad-print.css bluequad.css contact.html ext_buffer.html ext_c_api.html ext_ffi.html ext_ffi_api.html ext_ffi_semantics.html ext_ffi_tutorial.html ext_jit.html ext_profiler.html extensions.html install.html luajit.html running.htmldynasm
dasm_arm.h dasm_arm.lua dasm_arm64.h dasm_arm64.lua dasm_mips.h dasm_mips.lua dasm_mips64.lua dasm_ppc.h dasm_ppc.lua dasm_proto.h dasm_x64.lua dasm_x86.h dasm_x86.lua dynasm.luasrc
host
.gitignore README buildvm.c buildvm.h buildvm_asm.c buildvm_fold.c buildvm_lib.c buildvm_libbc.h buildvm_peobj.c genlibbc.lua genminilua.lua genversion.lua minilua.cjit
.gitignore bc.lua bcsave.lua dis_arm.lua dis_arm64.lua dis_arm64be.lua dis_mips.lua dis_mips64.lua dis_mips64el.lua dis_mips64r6.lua dis_mips64r6el.lua dis_mipsel.lua dis_ppc.lua dis_x64.lua dis_x86.lua dump.lua p.lua v.lua zone.luawolfssl
.github
workflows
ada.yml arduino.yml async-examples.yml async.yml atecc608-sim.yml bind.yml cmake-autoconf.yml cmake.yml codespell.yml coverity-scan-fixes.yml cryptocb-only.yml curl.yml cyrus-sasl.yml disable-pk-algs.yml docker-Espressif.yml docker-OpenWrt.yml emnet-nonblock.yml fil-c.yml freertos-mem-track.yml gencertbuf.yml grpc.yml haproxy.yml hostap-vm.yml intelasm-c-fallback.yml ipmitool.yml jwt-cpp.yml krb5.yml libspdm.yml libssh2.yml libvncserver.yml linuxkm.yml macos-apple-native-cert-validation.yml mbedtls.sh mbedtls.yml membrowse-comment.yml membrowse-onboard.yml membrowse-report.yml memcached.sh memcached.yml mono.yml mosquitto.yml msmtp.yml msys2.yml multi-arch.yml multi-compiler.yml net-snmp.yml nginx.yml no-malloc.yml no-tls.yml nss.sh nss.yml ntp.yml ocsp.yml openldap.yml openssh.yml openssl-ech.yml opensslcoexist.yml openvpn.yml os-check.yml packaging.yml pam-ipmi.yml pq-all.yml pr-commit-check.yml psk.yml puf.yml python.yml rng-tools.yml rust-wrapper.yml se050-sim.yml smallStackSize.yml socat.yml softhsm.yml sssd.yml stm32-sim.yml stsafe-a120-sim.yml stunnel.yml symbol-prefixes.yml threadx.yml tls-anvil.yml trackmemory.yml watcomc.yml win-csharp-test.yml wolfCrypt-Wconversion.yml wolfboot-integration.yml wolfsm.yml xcode.yml zephyr-4.x.yml zephyr.ymlIDE
ARDUINO
Arduino_README_prepend.md README.md include.am keywords.txt library.properties.template wolfssl-arduino.cpp wolfssl-arduino.sh wolfssl.hECLIPSE
Espressif
ESP-IDF
examples
template
CMakeLists.txt Makefile README.md partitions_singleapp_large.csv sdkconfig.defaults sdkconfig.defaults.esp8266wolfssl_benchmark
VisualGDB
wolfssl_benchmark_IDF_v4.4_ESP32.sln wolfssl_benchmark_IDF_v4.4_ESP32.vgdbproj wolfssl_benchmark_IDF_v5_ESP32.sln wolfssl_benchmark_IDF_v5_ESP32.vgdbproj wolfssl_benchmark_IDF_v5_ESP32C3.sln wolfssl_benchmark_IDF_v5_ESP32C3.vgdbproj wolfssl_benchmark_IDF_v5_ESP32S3.sln wolfssl_benchmark_IDF_v5_ESP32S3.vgdbprojwolfssl_client
CMakeLists.txt Makefile README.md README_server_sm.md partitions_singleapp_large.csv sdkconfig.defaults sdkconfig.defaults.esp32c2 sdkconfig.defaults.esp8266 wolfssl_client_ESP8266.vgdbprojwolfssl_server
CMakeLists.txt Makefile README.md README_server_sm.md partitions_singleapp_large.csv sdkconfig.defaults sdkconfig.defaults.esp32c2 sdkconfig.defaults.esp8266 wolfssl_server_ESP8266.vgdbprojwolfssl_test
VisualGDB
wolfssl_test-IDF_v5_ESP32.sln wolfssl_test-IDF_v5_ESP32.vgdbproj wolfssl_test-IDF_v5_ESP32C3.sln wolfssl_test-IDF_v5_ESP32C3.vgdbproj wolfssl_test-IDF_v5_ESP32C6.sln wolfssl_test-IDF_v5_ESP32C6.vgdbproj wolfssl_test_IDF_v5_ESP32S3.sln wolfssl_test_IDF_v5_ESP32S3.vgdbprojGCC-ARM
Makefile Makefile.bench Makefile.client Makefile.common Makefile.server Makefile.static Makefile.test README.md include.am linker.ld linker_fips.ldIAR-EWARM
embOS
SAMV71_XULT
embOS_SAMV71_XULT_user_settings
user_settings.h user_settings_simple_example.h user_settings_verbose_example.hembOS_wolfcrypt_benchmark_SAMV71_XULT
README_wolfcrypt_benchmark wolfcrypt_benchmark.ewd wolfcrypt_benchmark.ewpINTIME-RTOS
Makefile README.md include.am libwolfssl.c libwolfssl.vcxproj user_settings.h wolfExamples.c wolfExamples.h wolfExamples.sln wolfExamples.vcxproj wolfssl-lib.sln wolfssl-lib.vcxprojMQX
Makefile README-jp.md README.md client-tls.c include.am server-tls.c user_config.h user_settings.hMSVS-2019-AZSPHERE
wolfssl_new_azsphere
.gitignore CMakeLists.txt CMakeSettings.json app_manifest.json applibs_versions.h launch.vs.json main.cNETOS
Makefile.wolfcrypt.inc README.md include.am user_settings.h user_settings.h-cert2425 user_settings.h-cert3389 wolfssl_netos_custom.cPlatformIO
examples
wolfssl_benchmark
CMakeLists.txt README.md platformio.ini sdkconfig.defaults wolfssl_benchmark.code-workspaceROWLEY-CROSSWORKS-ARM
Kinetis_FlashPlacement.xml README.md arm_startup.c benchmark_main.c hw.h include.am kinetis_hw.c retarget.c test_main.c user_settings.h wolfssl.hzp wolfssl_ltc.hzpRenesas
e2studio
RA6M3
README.md README_APRA6M_en.md README_APRA6M_jp.md include.amRX72N
EnvisionKit
Simple
README_EN.md README_JP.mdwolfssl_demo
key_data.c key_data.h user_settings.h wolfssl_demo.c wolfssl_demo.h wolfssl_tsip_unit_test.cSTM32Cube
README.md STM32_Benchmarks.md default_conf.ftl include.am main.c wolfssl_example.c wolfssl_example.hWIN
README.txt include.am test.vcxproj user_settings.h user_settings_dtls.h wolfssl-fips.sln wolfssl-fips.vcxprojWIN-SRTP-KDF-140-3
README.txt include.am resource.h test.vcxproj user_settings.h wolfssl-fips.rc wolfssl-fips.sln wolfssl-fips.vcxprojWIN10
README.txt include.am resource.h test.vcxproj user_settings.h wolfssl-fips.rc wolfssl-fips.sln wolfssl-fips.vcxprojXCODE
Benchmark
include.amXilinxSDK
README.md bench.sh combine.sh eclipse_formatter_profile.xml graph.sh include.am user_settings.h wolfssl_example.capple-universal
wolfssl-multiplatform
iotsafe
Makefile README.md ca-cert.c devices.c devices.h include.am main.c memory-tls.c startup.c target.ld user_settings.hmynewt
README.md apps.wolfcrypttest.pkg.yml crypto.wolfssl.pkg.yml crypto.wolfssl.syscfg.yml include.am setup.shcerts
1024
ca-cert.der ca-cert.pem ca-key.der ca-key.pem client-cert.der client-cert.pem client-key.der client-key.pem client-keyPub.der dh1024.der dh1024.pem dsa-pub-1024.pem dsa1024.der dsa1024.pem include.am rsa1024.der server-cert.der server-cert.pem server-key.der server-key.pemcrl
extra-crls
ca-int-cert-revoked.pem claim-root.pem crl_critical_entry.pem crlnum_57oct.pem crlnum_64oct.pem general-server-crl.pem large_crlnum.pem large_crlnum2.pemdilithium
bench_dilithium_level2_key.der bench_dilithium_level3_key.der bench_dilithium_level5_key.der include.amecc
bp256r1-key.der bp256r1-key.pem ca-secp256k1-cert.pem ca-secp256k1-key.pem client-bp256r1-cert.der client-bp256r1-cert.pem client-secp256k1-cert.der client-secp256k1-cert.pem genecc.sh include.am secp256k1-key.der secp256k1-key.pem secp256k1-param.pem secp256k1-privkey.der secp256k1-privkey.pem server-bp256r1-cert.der server-bp256r1-cert.pem server-secp256k1-cert.der server-secp256k1-cert.pem server2-secp256k1-cert.der server2-secp256k1-cert.pem wolfssl.cnf wolfssl_384.cnfed25519
ca-ed25519-key.der ca-ed25519-key.pem ca-ed25519-priv.der ca-ed25519-priv.pem ca-ed25519.der ca-ed25519.pem client-ed25519-key.der client-ed25519-key.pem client-ed25519-priv.der client-ed25519-priv.pem client-ed25519.der client-ed25519.pem eddsa-ed25519.der eddsa-ed25519.pem gen-ed25519-certs.sh gen-ed25519-keys.sh gen-ed25519.sh include.am root-ed25519-key.der root-ed25519-key.pem root-ed25519-priv.der root-ed25519-priv.pem root-ed25519.der root-ed25519.pem server-ed25519-cert.pem server-ed25519-key.der server-ed25519-key.pem server-ed25519-priv.der server-ed25519-priv.pem server-ed25519.der server-ed25519.pemed448
ca-ed448-key.der ca-ed448-key.pem ca-ed448-priv.der ca-ed448-priv.pem ca-ed448.der ca-ed448.pem client-ed448-key.der client-ed448-key.pem client-ed448-priv.der client-ed448-priv.pem client-ed448.der client-ed448.pem gen-ed448-certs.sh gen-ed448-keys.sh include.am root-ed448-key.der root-ed448-key.pem root-ed448-priv.der root-ed448-priv.pem root-ed448.der root-ed448.pem server-ed448-cert.pem server-ed448-key.der server-ed448-key.pem server-ed448-priv.der server-ed448-priv.pem server-ed448.der server-ed448.pemexternal
DigiCertGlobalRootCA.pem README.txt ca-digicert-ev.pem ca-globalsign-root.pem ca-google-root.pem ca_collection.pem include.amintermediate
ca_false_intermediate
gentestcert.sh int_ca.key server.key test_ca.key test_ca.pem test_int_not_cacert.pem test_sign_bynoca_srv.pem wolfssl_base.conf wolfssl_srv.conflms
bc_hss_L2_H5_W8_root.der bc_hss_L3_H5_W4_root.der bc_lms_chain_ca.der bc_lms_chain_leaf.der bc_lms_native_bc_root.der bc_lms_sha256_h10_w8_root.der bc_lms_sha256_h5_w4_root.der include.ammldsa
README.txt include.am mldsa44-cert.der mldsa44-cert.pem mldsa44-key.pem mldsa44_bare-priv.der mldsa44_bare-seed.der mldsa44_oqskeypair.der mldsa44_priv-only.der mldsa44_pub-spki.der mldsa44_seed-only.der mldsa44_seed-priv.der mldsa65-cert.der mldsa65-cert.pem mldsa65-key.pem mldsa65_bare-priv.der mldsa65_bare-seed.der mldsa65_oqskeypair.der mldsa65_priv-only.der mldsa65_pub-spki.der mldsa65_seed-only.der mldsa65_seed-priv.der mldsa87-cert.der mldsa87-cert.pem mldsa87-key.pem mldsa87_bare-priv.der mldsa87_bare-seed.der mldsa87_oqskeypair.der mldsa87_priv-only.der mldsa87_pub-spki.der mldsa87_seed-only.der mldsa87_seed-priv.derocsp
imposter-root-ca-cert.der imposter-root-ca-cert.pem imposter-root-ca-key.der imposter-root-ca-key.pem include.am index-ca-and-intermediate-cas.txt index-ca-and-intermediate-cas.txt.attr index-intermediate1-ca-issued-certs.txt index-intermediate1-ca-issued-certs.txt.attr index-intermediate2-ca-issued-certs.txt index-intermediate2-ca-issued-certs.txt.attr index-intermediate3-ca-issued-certs.txt index-intermediate3-ca-issued-certs.txt.attr intermediate1-ca-cert.der intermediate1-ca-cert.pem intermediate1-ca-key.der intermediate1-ca-key.pem intermediate2-ca-cert.der intermediate2-ca-cert.pem intermediate2-ca-key.der intermediate2-ca-key.pem intermediate3-ca-cert.der intermediate3-ca-cert.pem intermediate3-ca-key.der intermediate3-ca-key.pem ocsp-responder-cert.der ocsp-responder-cert.pem ocsp-responder-key.der ocsp-responder-key.pem openssl.cnf renewcerts-for-test.sh renewcerts.sh root-ca-cert.der root-ca-cert.pem root-ca-crl.pem root-ca-key.der root-ca-key.pem server1-cert.der server1-cert.pem server1-chain-noroot.pem server1-key.der server1-key.pem server2-cert.der server2-cert.pem server2-key.der server2-key.pem server3-cert.der server3-cert.pem server3-key.der server3-key.pem server4-cert.der server4-cert.pem server4-key.der server4-key.pem server5-cert.der server5-cert.pem server5-key.der server5-key.pem test-leaf-response.der test-multi-response.der test-response-nointern.der test-response-rsapss.der test-response.derp521
ca-p521-key.der ca-p521-key.pem ca-p521-priv.der ca-p521-priv.pem ca-p521.der ca-p521.pem client-p521-key.der client-p521-key.pem client-p521-priv.der client-p521-priv.pem client-p521.der client-p521.pem gen-p521-certs.sh gen-p521-keys.sh include.am root-p521-key.der root-p521-key.pem root-p521-priv.der root-p521-priv.pem root-p521.der root-p521.pem server-p521-cert.pem server-p521-key.der server-p521-key.pem server-p521-priv.der server-p521-priv.pem server-p521.der server-p521.pemrpk
client-cert-rpk.der client-ecc-cert-rpk.der include.am server-cert-rpk.der server-ecc-cert-rpk.derrsapss
ca-3072-rsapss-key.der ca-3072-rsapss-key.pem ca-3072-rsapss-priv.der ca-3072-rsapss-priv.pem ca-3072-rsapss.der ca-3072-rsapss.pem ca-rsapss-key.der ca-rsapss-key.pem ca-rsapss-priv.der ca-rsapss-priv.pem ca-rsapss.der ca-rsapss.pem client-3072-rsapss-key.der client-3072-rsapss-key.pem client-3072-rsapss-priv.der client-3072-rsapss-priv.pem client-3072-rsapss.der client-3072-rsapss.pem client-rsapss-key.der client-rsapss-key.pem client-rsapss-priv.der client-rsapss-priv.pem client-rsapss.der client-rsapss.pem gen-rsapss-keys.sh include.am renew-rsapss-certs.sh root-3072-rsapss-key.der root-3072-rsapss-key.pem root-3072-rsapss-priv.der root-3072-rsapss-priv.pem root-3072-rsapss.der root-3072-rsapss.pem root-rsapss-key.der root-rsapss-key.pem root-rsapss-priv.der root-rsapss-priv.pem root-rsapss.der root-rsapss.pem server-3072-rsapss-cert.pem server-3072-rsapss-key.der server-3072-rsapss-key.pem server-3072-rsapss-priv.der server-3072-rsapss-priv.pem server-3072-rsapss.der server-3072-rsapss.pem server-mix-rsapss-cert.pem server-rsapss-cert.pem server-rsapss-key.der server-rsapss-key.pem server-rsapss-priv.der server-rsapss-priv.pem server-rsapss.der server-rsapss.pemslhdsa
bench_slhdsa_sha2_128f_key.der bench_slhdsa_sha2_128s_key.der bench_slhdsa_sha2_192f_key.der bench_slhdsa_sha2_192s_key.der bench_slhdsa_sha2_256f_key.der bench_slhdsa_sha2_256s_key.der bench_slhdsa_shake128f_key.der bench_slhdsa_shake128s_key.der bench_slhdsa_shake192f_key.der bench_slhdsa_shake192s_key.der bench_slhdsa_shake256f_key.der bench_slhdsa_shake256s_key.der client-mldsa44-priv.pem client-mldsa44-sha2.der client-mldsa44-sha2.pem client-mldsa44-shake.der client-mldsa44-shake.pem gen-slhdsa-mldsa-certs.sh include.am root-slhdsa-sha2-128s-priv.der root-slhdsa-sha2-128s-priv.pem root-slhdsa-sha2-128s.der root-slhdsa-sha2-128s.pem root-slhdsa-shake-128s-priv.der root-slhdsa-shake-128s-priv.pem root-slhdsa-shake-128s.der root-slhdsa-shake-128s.pem server-mldsa44-priv.pem server-mldsa44-sha2.der server-mldsa44-sha2.pem server-mldsa44-shake.der server-mldsa44-shake.pemsm2
ca-sm2-key.der ca-sm2-key.pem ca-sm2-priv.der ca-sm2-priv.pem ca-sm2.der ca-sm2.pem client-sm2-key.der client-sm2-key.pem client-sm2-priv.der client-sm2-priv.pem client-sm2.der client-sm2.pem fix_sm2_spki.py gen-sm2-certs.sh gen-sm2-keys.sh include.am root-sm2-key.der root-sm2-key.pem root-sm2-priv.der root-sm2-priv.pem root-sm2.der root-sm2.pem self-sm2-cert.pem self-sm2-key.pem self-sm2-priv.pem server-sm2-cert.der server-sm2-cert.pem server-sm2-key.der server-sm2-key.pem server-sm2-priv.der server-sm2-priv.pem server-sm2.der server-sm2.pemstatickeys
dh-ffdhe2048-params.pem dh-ffdhe2048-pub.der dh-ffdhe2048-pub.pem dh-ffdhe2048.der dh-ffdhe2048.pem ecc-secp256r1.der ecc-secp256r1.pem gen-static.sh include.am x25519-pub.der x25519-pub.pem x25519.der x25519.pemtest
catalog.txt cert-bad-neg-int.der cert-bad-oid.der cert-bad-utf8.der cert-ext-ia.cfg cert-ext-ia.der cert-ext-ia.pem cert-ext-joi.cfg cert-ext-joi.der cert-ext-joi.pem cert-ext-mnc.der cert-ext-multiple.cfg cert-ext-multiple.der cert-ext-multiple.pem cert-ext-nc-combined.der cert-ext-nc-combined.pem cert-ext-nc.cfg cert-ext-nc.der cert-ext-nc.pem cert-ext-ncdns.der cert-ext-ncdns.pem cert-ext-ncip.der cert-ext-ncip.pem cert-ext-ncmixed.der cert-ext-ncmulti.der cert-ext-ncmulti.pem cert-ext-ncrid.der cert-ext-ncrid.pem cert-ext-nct.cfg cert-ext-nct.der cert-ext-nct.pem cert-ext-ndir-exc.cfg cert-ext-ndir-exc.der cert-ext-ndir-exc.pem cert-ext-ndir.cfg cert-ext-ndir.der cert-ext-ndir.pem cert-ext-ns.der cert-over-max-altnames.cfg cert-over-max-altnames.der cert-over-max-altnames.pem cert-over-max-nc.cfg cert-over-max-nc.der cert-over-max-nc.pem client-ecc-cert-ski.hex cn-ip-literal.der cn-ip-wildcard.der crit-cert.pem crit-key.pem dh1024.der dh1024.pem dh512.der dh512.pem digsigku.pem encrypteddata.msg gen-badsig.sh gen-ext-certs.sh gen-testcerts.sh include.am kari-keyid-cms.msg ktri-keyid-cms.msg ossl-trusted-cert.pem server-badaltname.der server-badaltname.pem server-badaltnull.der server-badaltnull.pem server-badcn.der server-badcn.pem server-badcnnull.der server-badcnnull.pem server-cert-ecc-badsig.der server-cert-ecc-badsig.pem server-cert-rsa-badsig.der server-cert-rsa-badsig.pem server-duplicate-policy.pem server-garbage.der server-garbage.pem server-goodalt.der server-goodalt.pem server-goodaltwild.der server-goodaltwild.pem server-goodcn.der server-goodcn.pem server-goodcnwild.der server-goodcnwild.pem server-localhost.der server-localhost.pem smime-test-canon.p7s smime-test-multipart-badsig.p7s smime-test-multipart.p7s smime-test.p7stest-pathlen
assemble-chains.sh chainA-ICA1-key.pem chainA-ICA1-pathlen0.pem chainA-assembled.pem chainA-entity-key.pem chainA-entity.pem chainB-ICA1-key.pem chainB-ICA1-pathlen0.pem chainB-ICA2-key.pem chainB-ICA2-pathlen1.pem chainB-assembled.pem chainB-entity-key.pem chainB-entity.pem chainC-ICA1-key.pem chainC-ICA1-pathlen1.pem chainC-assembled.pem chainC-entity-key.pem chainC-entity.pem chainD-ICA1-key.pem chainD-ICA1-pathlen127.pem chainD-assembled.pem chainD-entity-key.pem chainD-entity.pem chainE-ICA1-key.pem chainE-ICA1-pathlen128.pem chainE-assembled.pem chainE-entity-key.pem chainE-entity.pem chainF-ICA1-key.pem chainF-ICA1-pathlen1.pem chainF-ICA2-key.pem chainF-ICA2-pathlen0.pem chainF-assembled.pem chainF-entity-key.pem chainF-entity.pem chainG-ICA1-key.pem chainG-ICA1-pathlen0.pem chainG-ICA2-key.pem chainG-ICA2-pathlen1.pem chainG-ICA3-key.pem chainG-ICA3-pathlen99.pem chainG-ICA4-key.pem chainG-ICA4-pathlen5.pem chainG-ICA5-key.pem chainG-ICA5-pathlen20.pem chainG-ICA6-key.pem chainG-ICA6-pathlen10.pem chainG-ICA7-key.pem chainG-ICA7-pathlen100.pem chainG-assembled.pem chainG-entity-key.pem chainG-entity.pem chainH-ICA1-key.pem chainH-ICA1-pathlen0.pem chainH-ICA2-key.pem chainH-ICA2-pathlen2.pem chainH-ICA3-key.pem chainH-ICA3-pathlen2.pem chainH-ICA4-key.pem chainH-ICA4-pathlen2.pem chainH-assembled.pem chainH-entity-key.pem chainH-entity.pem chainI-ICA1-key.pem chainI-ICA1-no_pathlen.pem chainI-ICA2-key.pem chainI-ICA2-no_pathlen.pem chainI-ICA3-key.pem chainI-ICA3-pathlen2.pem chainI-assembled.pem chainI-entity-key.pem chainI-entity.pem chainJ-ICA1-key.pem chainJ-ICA1-no_pathlen.pem chainJ-ICA2-key.pem chainJ-ICA2-no_pathlen.pem chainJ-ICA3-key.pem chainJ-ICA3-no_pathlen.pem chainJ-ICA4-key.pem chainJ-ICA4-pathlen2.pem chainJ-assembled.pem chainJ-entity-key.pem chainJ-entity.pem include.am refreshkeys.shtest-serial0
ee_normal.pem ee_serial0.pem generate_certs.sh include.am intermediate_serial0.pem root_serial0.pem root_serial0_key.pem selfsigned_nonca_serial0.pemxmss
bc_xmss_chain_ca.der bc_xmss_chain_leaf.der bc_xmss_sha2_10_256_root.der bc_xmss_sha2_16_256_root.der bc_xmssmt_sha2_20_2_256_root.der bc_xmssmt_sha2_20_4_256_root.der bc_xmssmt_sha2_40_8_256_root.der include.amcmake
Config.cmake.in README.md config.in functions.cmake include.am options.h.in wolfssl-config-version.cmake.in wolfssl-targets.cmake.indebian
changelog.in control.in copyright include.am libwolfssl-dev.install libwolfssl.install rules.indoc
dox_comments
header_files
aes.h arc4.h ascon.h asn.h asn_public.h blake2.h bn.h camellia.h chacha.h chacha20_poly1305.h cmac.h coding.h compress.h cryptocb.h curve25519.h curve448.h des3.h dh.h doxygen_groups.h doxygen_pages.h dsa.h ecc.h eccsi.h ed25519.h ed448.h error-crypt.h evp.h hash.h hmac.h iotsafe.h kdf.h logging.h md2.h md4.h md5.h memory.h ocsp.h pem.h pkcs11.h pkcs7.h poly1305.h psa.h puf.h pwdbased.h quic.h random.h ripemd.h rsa.h sakke.h sha.h sha256.h sha3.h sha512.h signature.h siphash.h srp.h ssl.h tfm.h types.h wc_encrypt.h wc_port.h wc_she.h wc_slhdsa.h wolfio.hheader_files-ja
aes.h arc4.h ascon.h asn.h asn_public.h blake2.h bn.h camellia.h chacha.h chacha20_poly1305.h cmac.h coding.h compress.h cryptocb.h curve25519.h curve448.h des3.h dh.h doxygen_groups.h doxygen_pages.h dsa.h ecc.h eccsi.h ed25519.h ed448.h error-crypt.h evp.h hash.h hmac.h iotsafe.h kdf.h logging.h md2.h md4.h md5.h memory.h ocsp.h pem.h pkcs11.h pkcs7.h poly1305.h psa.h pwdbased.h quic.h random.h ripemd.h rsa.h sakke.h sha.h sha256.h sha3.h sha512.h signature.h siphash.h srp.h ssl.h tfm.h types.h wc_encrypt.h wc_port.h wolfio.hexamples
async
Makefile README.md async_client.c async_server.c async_tls.c async_tls.h include.am user_settings.hconfigs
README.md include.am user_settings_EBSnet.h user_settings_all.h user_settings_arduino.h user_settings_baremetal.h user_settings_ca.h user_settings_curve25519nonblock.h user_settings_dtls13.h user_settings_eccnonblock.h user_settings_espressif.h user_settings_fipsv2.h user_settings_fipsv5.h user_settings_min_ecc.h user_settings_openssl_compat.h user_settings_pkcs7.h user_settings_platformio.h user_settings_pq.h user_settings_rsa_only.h user_settings_stm32.h user_settings_template.h user_settings_tls12.h user_settings_tls13.h user_settings_wolfboot_keytools.h user_settings_wolfssh.h user_settings_wolftpm.hechoclient
echoclient.c echoclient.h echoclient.sln echoclient.vcproj echoclient.vcxproj include.am quitlinuxkm
Kbuild Makefile README.md get_thread_size.c include.am linuxkm-fips-hash-wrapper.sh linuxkm-fips-hash.c linuxkm_memory.c linuxkm_memory.h linuxkm_wc_port.h lkcapi_aes_glue.c lkcapi_dh_glue.c lkcapi_ecdh_glue.c lkcapi_ecdsa_glue.c lkcapi_glue.c lkcapi_rsa_glue.c lkcapi_sha_glue.c module_exports.c.template module_hooks.c pie_redirect_table.c wolfcrypt.lds x86_vector_register_glue.cm4
ax_add_am_macro.m4 ax_am_jobserver.m4 ax_am_macros.m4 ax_append_compile_flags.m4 ax_append_flag.m4 ax_append_link_flags.m4 ax_append_to_file.m4 ax_atomic.m4 ax_bsdkm.m4 ax_check_compile_flag.m4 ax_check_link_flag.m4 ax_compiler_version.m4 ax_count_cpus.m4 ax_create_generic_config.m4 ax_debug.m4 ax_file_escapes.m4 ax_harden_compiler_flags.m4 ax_linuxkm.m4 ax_print_to_file.m4 ax_pthread.m4 ax_require_defined.m4 ax_tls.m4 ax_vcs_checkout.m4 hexversion.m4 lib_socket_nsl.m4 visibility.m4mqx
wolfcrypt_benchmark
ReferencedRSESystems.xml wolfcrypt_benchmark_twrk70f120m_Int_Flash_DDRData_Debug_PnE_U-MultiLink.launch wolfcrypt_benchmark_twrk70f120m_Int_Flash_DDRData_Release_PnE_U-MultiLink.launch wolfcrypt_benchmark_twrk70f120m_Int_Flash_SramData_Debug_JTrace.jlink wolfcrypt_benchmark_twrk70f120m_Int_Flash_SramData_Debug_JTrace.launch wolfcrypt_benchmark_twrk70f120m_Int_Flash_SramData_Debug_PnE_U-MultiLink.launch wolfcrypt_benchmark_twrk70f120m_Int_Flash_SramData_Release_PnE_U-MultiLink.launchwolfcrypt_test
ReferencedRSESystems.xml wolfcrypt_test_twrk70f120m_Int_Flash_DDRData_Debug_PnE_U-MultiLink.launch wolfcrypt_test_twrk70f120m_Int_Flash_DDRData_Release_PnE_U-MultiLink.launch wolfcrypt_test_twrk70f120m_Int_Flash_SramData_Debug_JTrace.jlink wolfcrypt_test_twrk70f120m_Int_Flash_SramData_Debug_JTrace.launch wolfcrypt_test_twrk70f120m_Int_Flash_SramData_Debug_PnE_U-MultiLink.launch wolfcrypt_test_twrk70f120m_Int_Flash_SramData_Release_PnE_U-MultiLink.launchwolfssl_client
ReferencedRSESystems.xml wolfssl_client_twrk70f120m_Int_Flash_DDRData_Debug_PnE_U-MultiLink.launch wolfssl_client_twrk70f120m_Int_Flash_DDRData_Release_PnE_U-MultiLink.launch wolfssl_client_twrk70f120m_Int_Flash_SramData_Debug_JTrace.jlink wolfssl_client_twrk70f120m_Int_Flash_SramData_Debug_JTrace.launch wolfssl_client_twrk70f120m_Int_Flash_SramData_Debug_PnE_U-MultiLink.launch wolfssl_client_twrk70f120m_Int_Flash_SramData_Release_PnE_U-MultiLink.launchscripts
aria-cmake-build-test.sh asn1_oid_sum.pl benchmark.test benchmark_compare.sh cleanup_testfiles.sh crl-gen-openssl.test crl-revoked.test dertoc.pl dtls.test dtlscid.test external.test google.test include.am makedistsmall.sh memtest.sh ocsp-responder-openssl-interop.test ocsp-stapling-with-ca-as-responder.test ocsp-stapling-with-wolfssl-responder.test ocsp-stapling.test ocsp-stapling2.test ocsp-stapling_tls13multi.test ocsp.test openssl.test openssl_srtp.test pem.test ping.test pkcallbacks.test psk.test resume.test rsapss.test sniffer-gen.sh sniffer-ipv6.pcap sniffer-static-rsa.pcap sniffer-testsuite.test sniffer-tls12-keylog.out sniffer-tls12-keylog.pcap sniffer-tls12-keylog.sslkeylog sniffer-tls13-dh-resume.pcap sniffer-tls13-dh.pcap sniffer-tls13-ecc-resume.pcap sniffer-tls13-ecc.pcap sniffer-tls13-hrr.pcap sniffer-tls13-keylog.out sniffer-tls13-keylog.pcap sniffer-tls13-keylog.sslkeylog sniffer-tls13-x25519-resume.pcap sniffer-tls13-x25519.pcap stm32l4-v4_0_1_build.sh tls13.test trusted_peer.test unit.test.in user_settings_asm.shsrc
bio.c conf.c crl.c dtls.c dtls13.c include.am internal.c keys.c ocsp.c pk.c pk_ec.c pk_rsa.c quic.c sniffer.c ssl.c ssl_api_cert.c ssl_api_crl_ocsp.c ssl_api_pk.c ssl_asn1.c ssl_bn.c ssl_certman.c ssl_crypto.c ssl_ech.c ssl_load.c ssl_misc.c ssl_p7p12.c ssl_sess.c ssl_sk.c tls.c tls13.c wolfio.c x509.c x509_str.ctests
api
api.h api_decl.h create_ocsp_test_blobs.py include.am test_aes.c test_aes.h test_arc4.c test_arc4.h test_ascon.c test_ascon.h test_ascon_kats.h test_asn.c test_asn.h test_blake2.c test_blake2.h test_camellia.c test_camellia.h test_certman.c test_certman.h test_chacha.c test_chacha.h test_chacha20_poly1305.c test_chacha20_poly1305.h test_cmac.c test_cmac.h test_curve25519.c test_curve25519.h test_curve448.c test_curve448.h test_des3.c test_des3.h test_dh.c test_dh.h test_digest.h test_dsa.c test_dsa.h test_dtls.c test_dtls.h test_ecc.c test_ecc.h test_ed25519.c test_ed25519.h test_ed448.c test_ed448.h test_evp.c test_evp.h test_evp_cipher.c test_evp_cipher.h test_evp_digest.c test_evp_digest.h test_evp_pkey.c test_evp_pkey.h test_hash.c test_hash.h test_hmac.c test_hmac.h test_md2.c test_md2.h test_md4.c test_md4.h test_md5.c test_md5.h test_mldsa.c test_mldsa.h test_mlkem.c test_mlkem.h test_ocsp.c test_ocsp.h test_ocsp_test_blobs.h test_ossl_asn1.c test_ossl_asn1.h test_ossl_bio.c test_ossl_bio.h test_ossl_bn.c test_ossl_bn.h test_ossl_cipher.c test_ossl_cipher.h test_ossl_dgst.c test_ossl_dgst.h test_ossl_dh.c test_ossl_dh.h test_ossl_dsa.c test_ossl_dsa.h test_ossl_ec.c test_ossl_ec.h test_ossl_ecx.c test_ossl_ecx.h test_ossl_mac.c test_ossl_mac.h test_ossl_obj.c test_ossl_obj.h test_ossl_p7p12.c test_ossl_p7p12.h test_ossl_pem.c test_ossl_pem.h test_ossl_rand.c test_ossl_rand.h test_ossl_rsa.c test_ossl_rsa.h test_ossl_sk.c test_ossl_sk.h test_ossl_x509.c test_ossl_x509.h test_ossl_x509_acert.c test_ossl_x509_acert.h test_ossl_x509_crypto.c test_ossl_x509_crypto.h test_ossl_x509_ext.c test_ossl_x509_ext.h test_ossl_x509_info.c test_ossl_x509_info.h test_ossl_x509_io.c test_ossl_x509_io.h test_ossl_x509_lu.c test_ossl_x509_lu.h test_ossl_x509_name.c test_ossl_x509_name.h test_ossl_x509_pk.c test_ossl_x509_pk.h test_ossl_x509_str.c test_ossl_x509_str.h test_ossl_x509_vp.c test_ossl_x509_vp.h test_pkcs12.c test_pkcs12.h test_pkcs7.c test_pkcs7.h test_poly1305.c test_poly1305.h test_random.c test_random.h test_rc2.c test_rc2.h test_ripemd.c test_ripemd.h test_rsa.c test_rsa.h test_sha.c test_sha.h test_sha256.c test_sha256.h test_sha3.c test_sha3.h test_sha512.c test_sha512.h test_she.c test_she.h test_signature.c test_signature.h test_slhdsa.c test_slhdsa.h test_sm2.c test_sm2.h test_sm3.c test_sm3.h test_sm4.c test_sm4.h test_tls.c test_tls.h test_tls13.c test_tls13.h test_tls_ext.c test_tls_ext.h test_wc_encrypt.c test_wc_encrypt.h test_wolfmath.c test_wolfmath.h test_x509.c test_x509.hwolfcrypt
benchmark
README.md benchmark-VS2022.sln benchmark-VS2022.vcxproj benchmark-VS2022.vcxproj.user benchmark.c benchmark.h benchmark.sln benchmark.vcproj benchmark.vcxproj include.amsrc
port
Espressif
esp_crt_bundle
README.md cacrt_all.pem cacrt_deprecated.pem cacrt_local.pem esp_crt_bundle.c gen_crt_bundle.py pio_install_cryptography.pyRenesas
README.md renesas_common.c renesas_fspsm_aes.c renesas_fspsm_rsa.c renesas_fspsm_sha.c renesas_fspsm_util.c renesas_rx64_hw_sha.c renesas_rx64_hw_util.c renesas_tsip_aes.c renesas_tsip_rsa.c renesas_tsip_sha.c renesas_tsip_util.carm
armv8-32-aes-asm.S armv8-32-aes-asm_c.c armv8-32-chacha-asm.S armv8-32-chacha-asm_c.c armv8-32-curve25519.S armv8-32-curve25519_c.c armv8-32-mlkem-asm.S armv8-32-mlkem-asm_c.c armv8-32-poly1305-asm.S armv8-32-poly1305-asm_c.c armv8-32-sha256-asm.S armv8-32-sha256-asm_c.c armv8-32-sha3-asm.S armv8-32-sha3-asm_c.c armv8-32-sha512-asm.S armv8-32-sha512-asm_c.c armv8-aes-asm.S armv8-aes-asm_c.c armv8-aes.c armv8-chacha-asm.S armv8-chacha-asm_c.c armv8-curve25519.S armv8-curve25519_c.c armv8-mlkem-asm.S armv8-mlkem-asm_c.c armv8-poly1305-asm.S armv8-poly1305-asm_c.c armv8-sha256-asm.S armv8-sha256-asm_c.c armv8-sha256.c armv8-sha3-asm.S armv8-sha3-asm_c.c armv8-sha512-asm.S armv8-sha512-asm_c.c armv8-sha512.c cryptoCell.c cryptoCellHash.c thumb2-aes-asm.S thumb2-aes-asm_c.c thumb2-chacha-asm.S thumb2-chacha-asm_c.c thumb2-curve25519.S thumb2-curve25519_c.c thumb2-mlkem-asm.S thumb2-mlkem-asm_c.c thumb2-poly1305-asm.S thumb2-poly1305-asm_c.c thumb2-sha256-asm.S thumb2-sha256-asm_c.c thumb2-sha3-asm.S thumb2-sha3-asm_c.c thumb2-sha512-asm.S thumb2-sha512-asm_c.ccaam
README.md caam_aes.c caam_doc.pdf caam_driver.c caam_error.c caam_integrity.c caam_qnx.c caam_sha.c wolfcaam_aes.c wolfcaam_cmac.c wolfcaam_ecdsa.c wolfcaam_fsl_nxp.c wolfcaam_hash.c wolfcaam_hmac.c wolfcaam_init.c wolfcaam_qnx.c wolfcaam_rsa.c wolfcaam_seco.c wolfcaam_x25519.cdevcrypto
README.md devcrypto_aes.c devcrypto_ecdsa.c devcrypto_hash.c devcrypto_hmac.c devcrypto_rsa.c devcrypto_x25519.c wc_devcrypto.criscv
riscv-64-aes.c riscv-64-chacha.c riscv-64-poly1305.c riscv-64-sha256.c riscv-64-sha3.c riscv-64-sha512.cwolfssl
openssl
aes.h asn1.h asn1t.h bio.h bn.h buffer.h camellia.h cmac.h cms.h compat_types.h conf.h crypto.h des.h dh.h dsa.h ec.h ec25519.h ec448.h ecdh.h ecdsa.h ed25519.h ed448.h engine.h err.h evp.h fips_rand.h hmac.h include.am kdf.h lhash.h md4.h md5.h modes.h obj_mac.h objects.h ocsp.h opensslconf.h opensslv.h ossl_typ.h pem.h pkcs12.h pkcs7.h rand.h rc4.h ripemd.h rsa.h safestack.h sha.h sha3.h srp.h ssl.h ssl23.h stack.h tls1.h txt_db.h ui.h x509.h x509_vfy.h x509v3.hwolfcrypt
port
Renesas
renesas-fspsm-crypt.h renesas-fspsm-types.h renesas-rx64-hw-crypt.h renesas-tsip-crypt.h renesas_cmn.h renesas_fspsm_internal.h renesas_sync.h renesas_tsip_internal.h renesas_tsip_types.hcaam
caam_driver.h caam_error.h caam_qnx.h wolfcaam.h wolfcaam_aes.h wolfcaam_cmac.h wolfcaam_ecdsa.h wolfcaam_fsl_nxp.h wolfcaam_hash.h wolfcaam_qnx.h wolfcaam_rsa.h wolfcaam_seco.h wolfcaam_sha.h wolfcaam_x25519.hwrapper
Ada
examples
src
aes_verify_main.adb rsa_verify_main.adb sha256_main.adb spark_sockets.adb spark_sockets.ads spark_terminal.adb spark_terminal.ads tls_client.adb tls_client.ads tls_client_main.adb tls_server.adb tls_server.ads tls_server_main.adbtests
src
aes_bindings_tests.adb aes_bindings_tests.ads rsa_verify_bindings_tests.adb rsa_verify_bindings_tests.ads sha256_bindings_tests.adb sha256_bindings_tests.ads tests.adbCSharp
wolfSSL-Example-IOCallbacks
App.config wolfSSL-Example-IOCallbacks.cs wolfSSL-Example-IOCallbacks.csprojwolfSSL-TLS-ServerThreaded
App.config wolfSSL-TLS-ServerThreaded.cs wolfSSL-TLS-ServerThreaded.csprojrust
wolfssl-wolfcrypt
src
aes.rs blake2.rs chacha20_poly1305.rs cmac.rs cmac_mac.rs curve25519.rs dh.rs dilithium.rs ecc.rs ecdsa.rs ed25519.rs ed448.rs fips.rs hkdf.rs hmac.rs hmac_mac.rs kdf.rs lib.rs lms.rs mlkem.rs mlkem_kem.rs pbkdf2_password_hash.rs prf.rs random.rs rsa.rs rsa_pkcs1v15.rs sha.rs sha_digest.rs sys.rstests
test_aes.rs test_blake2.rs test_chacha20_poly1305.rs test_cmac.rs test_cmac_mac.rs test_curve25519.rs test_dh.rs test_dilithium.rs test_ecc.rs test_ecdsa.rs test_ed25519.rs test_ed448.rs test_hkdf.rs test_hmac.rs test_hmac_mac.rs test_kdf.rs test_lms.rs test_mlkem.rs test_mlkem_kem.rs test_pbkdf2_password_hash.rs test_prf.rs test_random.rs test_rsa.rs test_rsa_pkcs1v15.rs test_sha.rs test_sha_digest.rs test_wolfcrypt.rszephyr
samples
wolfssl_benchmark
CMakeLists.txt README install_test.sh prj.conf sample.yaml zephyr_legacy.conf zephyr_v4.1.confwolfssl_test
CMakeLists.txt README install_test.sh prj-no-malloc.conf prj.conf sample.yaml zephyr_legacy.conf zephyr_v4.1.conf
luajit/src/lj_parse.c
raw
1/*
2** Lua parser (source code -> bytecode).
3** Copyright (C) 2005-2026 Mike Pall. See Copyright Notice in luajit.h
4**
5** Major portions taken verbatim or adapted from the Lua interpreter.
6** Copyright (C) 1994-2008 Lua.org, PUC-Rio. See Copyright Notice in lua.h
7*/
8
9#define lj_parse_c
10#define LUA_CORE
11
12#include "lj_obj.h"
13#include "lj_gc.h"
14#include "lj_err.h"
15#include "lj_debug.h"
16#include "lj_buf.h"
17#include "lj_str.h"
18#include "lj_tab.h"
19#include "lj_func.h"
20#include "lj_state.h"
21#include "lj_bc.h"
22#if LJ_HASFFI
23#include "lj_ctype.h"
24#endif
25#include "lj_strfmt.h"
26#include "lj_lex.h"
27#include "lj_parse.h"
28#include "lj_vm.h"
29#include "lj_vmevent.h"
30
31/* -- Parser structures and definitions ----------------------------------- */
32
33/* Expression kinds. */
34typedef enum {
35 /* Constant expressions must be first and in this order: */
36 VKNIL,
37 VKFALSE,
38 VKTRUE,
39 VKSTR, /* sval = string value */
40 VKNUM, /* nval = number value */
41 VKLAST = VKNUM,
42 VKCDATA, /* nval = cdata value, not treated as a constant expression */
43 /* Non-constant expressions follow: */
44 VLOCAL, /* info = local register, aux = vstack index */
45 VUPVAL, /* info = upvalue index, aux = vstack index */
46 VGLOBAL, /* sval = string value */
47 VINDEXED, /* info = table register, aux = index reg/byte/string const */
48 VJMP, /* info = instruction PC */
49 VRELOCABLE, /* info = instruction PC */
50 VNONRELOC, /* info = result register */
51 VCALL, /* info = instruction PC, aux = base */
52 VVOID
53} ExpKind;
54
55/* Expression descriptor. */
56typedef struct ExpDesc {
57 union {
58 struct {
59 uint32_t info; /* Primary info. */
60 uint32_t aux; /* Secondary info. */
61 } s;
62 TValue nval; /* Number value. */
63 GCstr *sval; /* String value. */
64 } u;
65 ExpKind k;
66 BCPos t; /* True condition jump list. */
67 BCPos f; /* False condition jump list. */
68} ExpDesc;
69
70/* Macros for expressions. */
71#define expr_hasjump(e) ((e)->t != (e)->f)
72
73#define expr_isk(e) ((e)->k <= VKLAST)
74#define expr_isk_nojump(e) (expr_isk(e) && !expr_hasjump(e))
75#define expr_isnumk(e) ((e)->k == VKNUM)
76#define expr_isnumk_nojump(e) (expr_isnumk(e) && !expr_hasjump(e))
77#define expr_isstrk(e) ((e)->k == VKSTR)
78
79#define expr_numtv(e) check_exp(expr_isnumk((e)), &(e)->u.nval)
80#define expr_numberV(e) numberVnum(expr_numtv((e)))
81
82/* Initialize expression. */
83static LJ_AINLINE void expr_init(ExpDesc *e, ExpKind k, uint32_t info)
84{
85 e->k = k;
86 e->u.s.info = info;
87 e->f = e->t = NO_JMP;
88}
89
90/* Check number constant for +-0. */
91static int expr_numiszero(ExpDesc *e)
92{
93 TValue *o = expr_numtv(e);
94 return tvisint(o) ? (intV(o) == 0) : tviszero(o);
95}
96
97/* Per-function linked list of scope blocks. */
98typedef struct FuncScope {
99 struct FuncScope *prev; /* Link to outer scope. */
100 MSize vstart; /* Start of block-local variables. */
101 uint8_t nactvar; /* Number of active vars outside the scope. */
102 uint8_t flags; /* Scope flags. */
103} FuncScope;
104
105#define FSCOPE_LOOP 0x01 /* Scope is a (breakable) loop. */
106#define FSCOPE_BREAK 0x02 /* Break used in scope. */
107#define FSCOPE_GOLA 0x04 /* Goto or label used in scope. */
108#define FSCOPE_UPVAL 0x08 /* Upvalue in scope. */
109#define FSCOPE_NOCLOSE 0x10 /* Do not close upvalues. */
110
111#define NAME_BREAK ((GCstr *)(uintptr_t)1)
112
113/* Index into variable stack. */
114typedef uint16_t VarIndex;
115#define LJ_MAX_VSTACK (65536 - LJ_MAX_UPVAL)
116
117/* Variable/goto/label info. */
118#define VSTACK_VAR_RW 0x01 /* R/W variable. */
119#define VSTACK_GOTO 0x02 /* Pending goto. */
120#define VSTACK_LABEL 0x04 /* Label. */
121
122/* Per-function state. */
123typedef struct FuncState {
124 GCtab *kt; /* Hash table for constants. */
125 LexState *ls; /* Lexer state. */
126 lua_State *L; /* Lua state. */
127 FuncScope *bl; /* Current scope. */
128 struct FuncState *prev; /* Enclosing function. */
129 BCPos pc; /* Next bytecode position. */
130 BCPos lasttarget; /* Bytecode position of last jump target. */
131 BCPos jpc; /* Pending jump list to next bytecode. */
132 BCReg freereg; /* First free register. */
133 BCReg nactvar; /* Number of active local variables. */
134 BCReg nkn, nkgc; /* Number of lua_Number/GCobj constants */
135 BCLine linedefined; /* First line of the function definition. */
136 BCInsLine *bcbase; /* Base of bytecode stack. */
137 BCPos bclim; /* Limit of bytecode stack. */
138 MSize vbase; /* Base of variable stack for this function. */
139 uint8_t flags; /* Prototype flags. */
140 uint8_t numparams; /* Number of parameters. */
141 uint8_t framesize; /* Fixed frame size. */
142 uint8_t nuv; /* Number of upvalues */
143 VarIndex varmap[LJ_MAX_LOCVAR]; /* Map from register to variable idx. */
144 VarIndex uvmap[LJ_MAX_UPVAL]; /* Map from upvalue to variable idx. */
145 VarIndex uvtmp[LJ_MAX_UPVAL]; /* Temporary upvalue map. */
146} FuncState;
147
148/* Binary and unary operators. ORDER OPR */
149typedef enum BinOpr {
150 OPR_ADD, OPR_SUB, OPR_MUL, OPR_DIV, OPR_MOD, OPR_POW, /* ORDER ARITH */
151 OPR_CONCAT,
152 OPR_NE, OPR_EQ,
153 OPR_LT, OPR_GE, OPR_LE, OPR_GT,
154 OPR_AND, OPR_OR,
155 OPR_NOBINOPR
156} BinOpr;
157
158LJ_STATIC_ASSERT((int)BC_ISGE-(int)BC_ISLT == (int)OPR_GE-(int)OPR_LT);
159LJ_STATIC_ASSERT((int)BC_ISLE-(int)BC_ISLT == (int)OPR_LE-(int)OPR_LT);
160LJ_STATIC_ASSERT((int)BC_ISGT-(int)BC_ISLT == (int)OPR_GT-(int)OPR_LT);
161LJ_STATIC_ASSERT((int)BC_SUBVV-(int)BC_ADDVV == (int)OPR_SUB-(int)OPR_ADD);
162LJ_STATIC_ASSERT((int)BC_MULVV-(int)BC_ADDVV == (int)OPR_MUL-(int)OPR_ADD);
163LJ_STATIC_ASSERT((int)BC_DIVVV-(int)BC_ADDVV == (int)OPR_DIV-(int)OPR_ADD);
164LJ_STATIC_ASSERT((int)BC_MODVV-(int)BC_ADDVV == (int)OPR_MOD-(int)OPR_ADD);
165
166#ifdef LUA_USE_ASSERT
167#define lj_assertFS(c, ...) (lj_assertG_(G(fs->L), (c), __VA_ARGS__))
168#else
169#define lj_assertFS(c, ...) ((void)fs)
170#endif
171
172/* -- Error handling ------------------------------------------------------ */
173
174LJ_NORET LJ_NOINLINE static void err_syntax(LexState *ls, ErrMsg em)
175{
176 lj_lex_error(ls, ls->tok, em);
177}
178
179LJ_NORET LJ_NOINLINE static void err_token(LexState *ls, LexToken tok)
180{
181 lj_lex_error(ls, ls->tok, LJ_ERR_XTOKEN, lj_lex_token2str(ls, tok));
182}
183
184LJ_NORET static void err_limit(FuncState *fs, uint32_t limit, const char *what)
185{
186 if (fs->linedefined == 0)
187 lj_lex_error(fs->ls, 0, LJ_ERR_XLIMM, limit, what);
188 else
189 lj_lex_error(fs->ls, 0, LJ_ERR_XLIMF, fs->linedefined, limit, what);
190}
191
192#define checklimit(fs, v, l, m) if ((v) >= (l)) err_limit(fs, l, m)
193#define checklimitgt(fs, v, l, m) if ((v) > (l)) err_limit(fs, l, m)
194#define checkcond(ls, c, em) { if (!(c)) err_syntax(ls, em); }
195
196/* -- Management of constants --------------------------------------------- */
197
198/* Return bytecode encoding for primitive constant. */
199#define const_pri(e) check_exp((e)->k <= VKTRUE, (e)->k)
200
201#define tvhaskslot(o) ((o)->u32.hi == 0)
202#define tvkslot(o) ((o)->u32.lo)
203
204/* Add a number constant. */
205static BCReg const_num(FuncState *fs, ExpDesc *e)
206{
207 lua_State *L = fs->L;
208 TValue *o;
209 lj_assertFS(expr_isnumk(e), "bad usage");
210 o = lj_tab_set(L, fs->kt, &e->u.nval);
211 if (tvhaskslot(o))
212 return tvkslot(o);
213 o->u64 = fs->nkn;
214 return fs->nkn++;
215}
216
217/* Add a GC object constant. */
218static BCReg const_gc(FuncState *fs, GCobj *gc, uint32_t itype)
219{
220 lua_State *L = fs->L;
221 TValue key, *o;
222 setgcV(L, &key, gc, itype);
223 /* NOBARRIER: the key is new or kept alive. */
224 o = lj_tab_set(L, fs->kt, &key);
225 if (tvhaskslot(o))
226 return tvkslot(o);
227 o->u64 = fs->nkgc;
228 return fs->nkgc++;
229}
230
231/* Add a string constant. */
232static BCReg const_str(FuncState *fs, ExpDesc *e)
233{
234 lj_assertFS(expr_isstrk(e) || e->k == VGLOBAL, "bad usage");
235 return const_gc(fs, obj2gco(e->u.sval), LJ_TSTR);
236}
237
238/* Anchor string constant to avoid GC. */
239GCstr *lj_parse_keepstr(LexState *ls, const char *str, size_t len)
240{
241 /* NOBARRIER: the key is new or kept alive. */
242 lua_State *L = ls->L;
243 GCstr *s = lj_str_new(L, str, len);
244 TValue *tv = lj_tab_setstr(L, ls->fs->kt, s);
245 if (tvisnil(tv)) setboolV(tv, 1);
246 lj_gc_check(L);
247 return s;
248}
249
250#if LJ_HASFFI
251/* Anchor cdata to avoid GC. */
252void lj_parse_keepcdata(LexState *ls, TValue *tv, GCcdata *cd)
253{
254 /* NOBARRIER: the key is new or kept alive. */
255 lua_State *L = ls->L;
256 setcdataV(L, tv, cd);
257 setboolV(lj_tab_set(L, ls->fs->kt, tv), 1);
258}
259#endif
260
261/* -- Jump list handling -------------------------------------------------- */
262
263/* Get next element in jump list. */
264static BCPos jmp_next(FuncState *fs, BCPos pc)
265{
266 ptrdiff_t delta = bc_j(fs->bcbase[pc].ins);
267 if ((BCPos)delta == NO_JMP)
268 return NO_JMP;
269 else
270 return (BCPos)(((ptrdiff_t)pc+1)+delta);
271}
272
273/* Check if any of the instructions on the jump list produce no value. */
274static int jmp_novalue(FuncState *fs, BCPos list)
275{
276 for (; list != NO_JMP; list = jmp_next(fs, list)) {
277 BCIns p = fs->bcbase[list >= 1 ? list-1 : list].ins;
278 if (!(bc_op(p) == BC_ISTC || bc_op(p) == BC_ISFC || bc_a(p) == NO_REG))
279 return 1;
280 }
281 return 0;
282}
283
284/* Patch register of test instructions. */
285static int jmp_patchtestreg(FuncState *fs, BCPos pc, BCReg reg)
286{
287 BCInsLine *ilp = &fs->bcbase[pc >= 1 ? pc-1 : pc];
288 BCOp op = bc_op(ilp->ins);
289 if (op == BC_ISTC || op == BC_ISFC) {
290 if (reg != NO_REG && reg != bc_d(ilp->ins)) {
291 setbc_a(&ilp->ins, reg);
292 } else { /* Nothing to store or already in the right register. */
293 setbc_op(&ilp->ins, op+(BC_IST-BC_ISTC));
294 setbc_a(&ilp->ins, 0);
295 }
296 } else if (bc_a(ilp->ins) == NO_REG) {
297 if (reg == NO_REG) {
298 ilp->ins = BCINS_AJ(BC_JMP, bc_a(fs->bcbase[pc].ins), 0);
299 } else {
300 setbc_a(&ilp->ins, reg);
301 if (reg >= bc_a(ilp[1].ins))
302 setbc_a(&ilp[1].ins, reg+1);
303 }
304 } else {
305 return 0; /* Cannot patch other instructions. */
306 }
307 return 1;
308}
309
310/* Drop values for all instructions on jump list. */
311static void jmp_dropval(FuncState *fs, BCPos list)
312{
313 for (; list != NO_JMP; list = jmp_next(fs, list))
314 jmp_patchtestreg(fs, list, NO_REG);
315}
316
317/* Patch jump instruction to target. */
318static void jmp_patchins(FuncState *fs, BCPos pc, BCPos dest)
319{
320 BCIns *jmp = &fs->bcbase[pc].ins;
321 BCPos offset = dest-(pc+1)+BCBIAS_J;
322 lj_assertFS(dest != NO_JMP, "uninitialized jump target");
323 if (offset > BCMAX_D)
324 err_syntax(fs->ls, LJ_ERR_XJUMP);
325 setbc_d(jmp, offset);
326}
327
328/* Append to jump list. */
329static void jmp_append(FuncState *fs, BCPos *l1, BCPos l2)
330{
331 if (l2 == NO_JMP) {
332 return;
333 } else if (*l1 == NO_JMP) {
334 *l1 = l2;
335 } else {
336 BCPos list = *l1;
337 BCPos next;
338 while ((next = jmp_next(fs, list)) != NO_JMP) /* Find last element. */
339 list = next;
340 jmp_patchins(fs, list, l2);
341 }
342}
343
344/* Patch jump list and preserve produced values. */
345static void jmp_patchval(FuncState *fs, BCPos list, BCPos vtarget,
346 BCReg reg, BCPos dtarget)
347{
348 while (list != NO_JMP) {
349 BCPos next = jmp_next(fs, list);
350 if (jmp_patchtestreg(fs, list, reg))
351 jmp_patchins(fs, list, vtarget); /* Jump to target with value. */
352 else
353 jmp_patchins(fs, list, dtarget); /* Jump to default target. */
354 list = next;
355 }
356}
357
358/* Jump to following instruction. Append to list of pending jumps. */
359static void jmp_tohere(FuncState *fs, BCPos list)
360{
361 fs->lasttarget = fs->pc;
362 jmp_append(fs, &fs->jpc, list);
363}
364
365/* Patch jump list to target. */
366static void jmp_patch(FuncState *fs, BCPos list, BCPos target)
367{
368 if (target == fs->pc) {
369 jmp_tohere(fs, list);
370 } else {
371 lj_assertFS(target < fs->pc, "bad jump target");
372 jmp_patchval(fs, list, target, NO_REG, target);
373 }
374}
375
376/* -- Bytecode register allocator ----------------------------------------- */
377
378/* Bump frame size. */
379static void bcreg_bump(FuncState *fs, BCReg n)
380{
381 BCReg sz = fs->freereg + n;
382 if (sz > fs->framesize) {
383 if (sz >= LJ_MAX_SLOTS)
384 err_syntax(fs->ls, LJ_ERR_XSLOTS);
385 fs->framesize = (uint8_t)sz;
386 }
387}
388
389/* Reserve registers. */
390static void bcreg_reserve(FuncState *fs, BCReg n)
391{
392 bcreg_bump(fs, n);
393 fs->freereg += n;
394}
395
396/* Free register. */
397static void bcreg_free(FuncState *fs, BCReg reg)
398{
399 if (reg >= fs->nactvar) {
400 fs->freereg--;
401 lj_assertFS(reg == fs->freereg, "bad regfree");
402 }
403}
404
405/* Free register for expression. */
406static void expr_free(FuncState *fs, ExpDesc *e)
407{
408 if (e->k == VNONRELOC)
409 bcreg_free(fs, e->u.s.info);
410}
411
412/* -- Bytecode emitter ---------------------------------------------------- */
413
414/* Emit bytecode instruction. */
415static BCPos bcemit_INS(FuncState *fs, BCIns ins)
416{
417 BCPos pc = fs->pc;
418 LexState *ls = fs->ls;
419 jmp_patchval(fs, fs->jpc, pc, NO_REG, pc);
420 fs->jpc = NO_JMP;
421 if (LJ_UNLIKELY(pc >= fs->bclim)) {
422 ptrdiff_t base = fs->bcbase - ls->bcstack;
423 checklimit(fs, ls->sizebcstack, LJ_MAX_BCINS, "bytecode instructions");
424 lj_mem_growvec(fs->L, ls->bcstack, ls->sizebcstack, LJ_MAX_BCINS,BCInsLine);
425 fs->bclim = (BCPos)(ls->sizebcstack - base);
426 fs->bcbase = ls->bcstack + base;
427 }
428 fs->bcbase[pc].ins = ins;
429 fs->bcbase[pc].line = ls->lastline;
430 fs->pc = pc+1;
431 return pc;
432}
433
434#define bcemit_ABC(fs, o, a, b, c) bcemit_INS(fs, BCINS_ABC(o, a, b, c))
435#define bcemit_AD(fs, o, a, d) bcemit_INS(fs, BCINS_AD(o, a, d))
436#define bcemit_AJ(fs, o, a, j) bcemit_INS(fs, BCINS_AJ(o, a, j))
437
438#define bcptr(fs, e) (&(fs)->bcbase[(e)->u.s.info].ins)
439
440/* -- Bytecode emitter for expressions ------------------------------------ */
441
442/* Discharge non-constant expression to any register. */
443static void expr_discharge(FuncState *fs, ExpDesc *e)
444{
445 BCIns ins;
446 if (e->k == VUPVAL) {
447 ins = BCINS_AD(BC_UGET, 0, e->u.s.info);
448 } else if (e->k == VGLOBAL) {
449 ins = BCINS_AD(BC_GGET, 0, const_str(fs, e));
450 } else if (e->k == VINDEXED) {
451 BCReg rc = e->u.s.aux;
452 if ((int32_t)rc < 0) {
453 ins = BCINS_ABC(BC_TGETS, 0, e->u.s.info, ~rc);
454 } else if (rc > BCMAX_C) {
455 ins = BCINS_ABC(BC_TGETB, 0, e->u.s.info, rc-(BCMAX_C+1));
456 } else {
457 bcreg_free(fs, rc);
458 ins = BCINS_ABC(BC_TGETV, 0, e->u.s.info, rc);
459 }
460 bcreg_free(fs, e->u.s.info);
461 } else if (e->k == VCALL) {
462 e->u.s.info = e->u.s.aux;
463 e->k = VNONRELOC;
464 return;
465 } else if (e->k == VLOCAL) {
466 e->k = VNONRELOC;
467 return;
468 } else {
469 return;
470 }
471 e->u.s.info = bcemit_INS(fs, ins);
472 e->k = VRELOCABLE;
473}
474
475/* Emit bytecode to set a range of registers to nil. */
476static void bcemit_nil(FuncState *fs, BCReg from, BCReg n)
477{
478 if (fs->pc > fs->lasttarget) { /* No jumps to current position? */
479 BCIns *ip = &fs->bcbase[fs->pc-1].ins;
480 BCReg pto, pfrom = bc_a(*ip);
481 switch (bc_op(*ip)) { /* Try to merge with the previous instruction. */
482 case BC_KPRI:
483 if (bc_d(*ip) != ~LJ_TNIL) break;
484 if (from == pfrom) {
485 if (n == 1) return;
486 } else if (from == pfrom+1) {
487 from = pfrom;
488 n++;
489 } else {
490 break;
491 }
492 *ip = BCINS_AD(BC_KNIL, from, from+n-1); /* Replace KPRI. */
493 return;
494 case BC_KNIL:
495 pto = bc_d(*ip);
496 if (pfrom <= from && from <= pto+1) { /* Can we connect both ranges? */
497 if (from+n-1 > pto)
498 setbc_d(ip, from+n-1); /* Patch previous instruction range. */
499 return;
500 }
501 break;
502 default:
503 break;
504 }
505 }
506 /* Emit new instruction or replace old instruction. */
507 bcemit_INS(fs, n == 1 ? BCINS_AD(BC_KPRI, from, VKNIL) :
508 BCINS_AD(BC_KNIL, from, from+n-1));
509}
510
511/* Discharge an expression to a specific register. Ignore branches. */
512static void expr_toreg_nobranch(FuncState *fs, ExpDesc *e, BCReg reg)
513{
514 BCIns ins;
515 expr_discharge(fs, e);
516 if (e->k == VKSTR) {
517 ins = BCINS_AD(BC_KSTR, reg, const_str(fs, e));
518 } else if (e->k == VKNUM) {
519#if LJ_DUALNUM
520 cTValue *tv = expr_numtv(e);
521 if (tvisint(tv) && checki16(intV(tv)))
522 ins = BCINS_AD(BC_KSHORT, reg, (BCReg)(uint16_t)intV(tv));
523 else
524#else
525 int64_t i64;
526 int32_t k;
527 if (lj_num2int_cond(expr_numberV(e), i64, k, checki16((int32_t)i64)))
528 ins = BCINS_AD(BC_KSHORT, reg, (BCReg)(uint16_t)k);
529 else
530#endif
531 ins = BCINS_AD(BC_KNUM, reg, const_num(fs, e));
532#if LJ_HASFFI
533 } else if (e->k == VKCDATA) {
534 fs->flags |= PROTO_FFI;
535 ins = BCINS_AD(BC_KCDATA, reg,
536 const_gc(fs, obj2gco(cdataV(&e->u.nval)), LJ_TCDATA));
537#endif
538 } else if (e->k == VRELOCABLE) {
539 setbc_a(bcptr(fs, e), reg);
540 goto noins;
541 } else if (e->k == VNONRELOC) {
542 if (reg == e->u.s.info)
543 goto noins;
544 ins = BCINS_AD(BC_MOV, reg, e->u.s.info);
545 } else if (e->k == VKNIL) {
546 bcemit_nil(fs, reg, 1);
547 goto noins;
548 } else if (e->k <= VKTRUE) {
549 ins = BCINS_AD(BC_KPRI, reg, const_pri(e));
550 } else {
551 lj_assertFS(e->k == VVOID || e->k == VJMP, "bad expr type %d", e->k);
552 return;
553 }
554 bcemit_INS(fs, ins);
555noins:
556 e->u.s.info = reg;
557 e->k = VNONRELOC;
558}
559
560/* Forward declaration. */
561static BCPos bcemit_jmp(FuncState *fs);
562
563/* Discharge an expression to a specific register. */
564static void expr_toreg(FuncState *fs, ExpDesc *e, BCReg reg)
565{
566 expr_toreg_nobranch(fs, e, reg);
567 if (e->k == VJMP)
568 jmp_append(fs, &e->t, e->u.s.info); /* Add it to the true jump list. */
569 if (expr_hasjump(e)) { /* Discharge expression with branches. */
570 BCPos jend, jfalse = NO_JMP, jtrue = NO_JMP;
571 if (jmp_novalue(fs, e->t) || jmp_novalue(fs, e->f)) {
572 BCPos jval = (e->k == VJMP) ? NO_JMP : bcemit_jmp(fs);
573 jfalse = bcemit_AD(fs, BC_KPRI, reg, VKFALSE);
574 bcemit_AJ(fs, BC_JMP, fs->freereg, 1);
575 jtrue = bcemit_AD(fs, BC_KPRI, reg, VKTRUE);
576 jmp_tohere(fs, jval);
577 }
578 jend = fs->pc;
579 fs->lasttarget = jend;
580 jmp_patchval(fs, e->f, jend, reg, jfalse);
581 jmp_patchval(fs, e->t, jend, reg, jtrue);
582 }
583 e->f = e->t = NO_JMP;
584 e->u.s.info = reg;
585 e->k = VNONRELOC;
586}
587
588/* Discharge an expression to the next free register. */
589static void expr_tonextreg(FuncState *fs, ExpDesc *e)
590{
591 expr_discharge(fs, e);
592 expr_free(fs, e);
593 bcreg_reserve(fs, 1);
594 expr_toreg(fs, e, fs->freereg - 1);
595}
596
597/* Discharge an expression to any register. */
598static BCReg expr_toanyreg(FuncState *fs, ExpDesc *e)
599{
600 expr_discharge(fs, e);
601 if (e->k == VNONRELOC) {
602 if (!expr_hasjump(e)) return e->u.s.info; /* Already in a register. */
603 if (e->u.s.info >= fs->nactvar) {
604 expr_toreg(fs, e, e->u.s.info); /* Discharge to temp. register. */
605 return e->u.s.info;
606 }
607 }
608 expr_tonextreg(fs, e); /* Discharge to next register. */
609 return e->u.s.info;
610}
611
612/* Partially discharge expression to a value. */
613static void expr_toval(FuncState *fs, ExpDesc *e)
614{
615 if (expr_hasjump(e))
616 expr_toanyreg(fs, e);
617 else
618 expr_discharge(fs, e);
619}
620
621/* Emit store for LHS expression. */
622static void bcemit_store(FuncState *fs, ExpDesc *var, ExpDesc *e)
623{
624 BCIns ins;
625 if (var->k == VLOCAL) {
626 fs->ls->vstack[var->u.s.aux].info |= VSTACK_VAR_RW;
627 expr_free(fs, e);
628 expr_toreg(fs, e, var->u.s.info);
629 return;
630 } else if (var->k == VUPVAL) {
631 fs->ls->vstack[var->u.s.aux].info |= VSTACK_VAR_RW;
632 expr_toval(fs, e);
633 if (e->k <= VKTRUE)
634 ins = BCINS_AD(BC_USETP, var->u.s.info, const_pri(e));
635 else if (e->k == VKSTR)
636 ins = BCINS_AD(BC_USETS, var->u.s.info, const_str(fs, e));
637 else if (e->k == VKNUM)
638 ins = BCINS_AD(BC_USETN, var->u.s.info, const_num(fs, e));
639 else
640 ins = BCINS_AD(BC_USETV, var->u.s.info, expr_toanyreg(fs, e));
641 } else if (var->k == VGLOBAL) {
642 BCReg ra = expr_toanyreg(fs, e);
643 ins = BCINS_AD(BC_GSET, ra, const_str(fs, var));
644 } else {
645 BCReg ra, rc;
646 lj_assertFS(var->k == VINDEXED, "bad expr type %d", var->k);
647 ra = expr_toanyreg(fs, e);
648 rc = var->u.s.aux;
649 if ((int32_t)rc < 0) {
650 ins = BCINS_ABC(BC_TSETS, ra, var->u.s.info, ~rc);
651 } else if (rc > BCMAX_C) {
652 ins = BCINS_ABC(BC_TSETB, ra, var->u.s.info, rc-(BCMAX_C+1));
653 } else {
654#ifdef LUA_USE_ASSERT
655 /* Free late alloced key reg to avoid assert on free of value reg. */
656 /* This can only happen when called from expr_table(). */
657 if (e->k == VNONRELOC && ra >= fs->nactvar && rc >= ra)
658 bcreg_free(fs, rc);
659#endif
660 ins = BCINS_ABC(BC_TSETV, ra, var->u.s.info, rc);
661 }
662 }
663 bcemit_INS(fs, ins);
664 expr_free(fs, e);
665}
666
667/* Emit method lookup expression. */
668static void bcemit_method(FuncState *fs, ExpDesc *e, ExpDesc *key)
669{
670 BCReg idx, func, fr2, obj = expr_toanyreg(fs, e);
671 expr_free(fs, e);
672 func = fs->freereg;
673 fr2 = fs->ls->fr2;
674 bcemit_AD(fs, BC_MOV, func+1+fr2, obj); /* Copy object to 1st argument. */
675 lj_assertFS(expr_isstrk(key), "bad usage");
676 idx = const_str(fs, key);
677 if (idx <= BCMAX_C) {
678 bcreg_reserve(fs, 2+fr2);
679 bcemit_ABC(fs, BC_TGETS, func, obj, idx);
680 } else {
681 bcreg_reserve(fs, 3+fr2);
682 bcemit_AD(fs, BC_KSTR, func+2+fr2, idx);
683 bcemit_ABC(fs, BC_TGETV, func, obj, func+2+fr2);
684 fs->freereg--;
685 }
686 e->u.s.info = func;
687 e->k = VNONRELOC;
688}
689
690/* -- Bytecode emitter for branches --------------------------------------- */
691
692/* Emit unconditional branch. */
693static BCPos bcemit_jmp(FuncState *fs)
694{
695 BCPos jpc = fs->jpc;
696 BCPos j = fs->pc - 1;
697 BCIns *ip = &fs->bcbase[j].ins;
698 fs->jpc = NO_JMP;
699 if ((int32_t)j >= (int32_t)fs->lasttarget && bc_op(*ip) == BC_UCLO) {
700 setbc_j(ip, NO_JMP);
701 fs->lasttarget = j+1;
702 } else {
703 j = bcemit_AJ(fs, BC_JMP, fs->freereg, NO_JMP);
704 }
705 jmp_append(fs, &j, jpc);
706 return j;
707}
708
709/* Invert branch condition of bytecode instruction. */
710static void invertcond(FuncState *fs, ExpDesc *e)
711{
712 BCIns *ip = &fs->bcbase[e->u.s.info - 1].ins;
713 setbc_op(ip, bc_op(*ip)^1);
714}
715
716/* Emit conditional branch. */
717static BCPos bcemit_branch(FuncState *fs, ExpDesc *e, int cond)
718{
719 BCPos pc;
720 if (e->k == VRELOCABLE) {
721 BCIns *ip = bcptr(fs, e);
722 if (bc_op(*ip) == BC_NOT) {
723 *ip = BCINS_AD(cond ? BC_ISF : BC_IST, 0, bc_d(*ip));
724 return bcemit_jmp(fs);
725 }
726 }
727 if (e->k != VNONRELOC) {
728 bcreg_reserve(fs, 1);
729 expr_toreg_nobranch(fs, e, fs->freereg-1);
730 }
731 bcemit_AD(fs, cond ? BC_ISTC : BC_ISFC, NO_REG, e->u.s.info);
732 pc = bcemit_jmp(fs);
733 expr_free(fs, e);
734 return pc;
735}
736
737/* Emit branch on true condition. */
738static void bcemit_branch_t(FuncState *fs, ExpDesc *e)
739{
740 BCPos pc;
741 expr_discharge(fs, e);
742 if (e->k == VKSTR || e->k == VKNUM || e->k == VKTRUE)
743 pc = NO_JMP; /* Never jump. */
744 else if (e->k == VJMP)
745 invertcond(fs, e), pc = e->u.s.info;
746 else if (e->k == VKFALSE || e->k == VKNIL)
747 expr_toreg_nobranch(fs, e, NO_REG), pc = bcemit_jmp(fs);
748 else
749 pc = bcemit_branch(fs, e, 0);
750 jmp_append(fs, &e->f, pc);
751 jmp_tohere(fs, e->t);
752 e->t = NO_JMP;
753}
754
755/* Emit branch on false condition. */
756static void bcemit_branch_f(FuncState *fs, ExpDesc *e)
757{
758 BCPos pc;
759 expr_discharge(fs, e);
760 if (e->k == VKNIL || e->k == VKFALSE)
761 pc = NO_JMP; /* Never jump. */
762 else if (e->k == VJMP)
763 pc = e->u.s.info;
764 else if (e->k == VKSTR || e->k == VKNUM || e->k == VKTRUE)
765 expr_toreg_nobranch(fs, e, NO_REG), pc = bcemit_jmp(fs);
766 else
767 pc = bcemit_branch(fs, e, 1);
768 jmp_append(fs, &e->t, pc);
769 jmp_tohere(fs, e->f);
770 e->f = NO_JMP;
771}
772
773/* -- Bytecode emitter for operators -------------------------------------- */
774
775/* Try constant-folding of arithmetic operators. */
776static int foldarith(BinOpr opr, ExpDesc *e1, ExpDesc *e2)
777{
778 TValue o;
779 lua_Number n;
780 if (!expr_isnumk_nojump(e1) || !expr_isnumk_nojump(e2)) return 0;
781 n = lj_vm_foldarith(expr_numberV(e1), expr_numberV(e2), (int)opr-OPR_ADD);
782 setnumV(&o, n);
783 if (tvisnan(&o) || tvismzero(&o)) return 0; /* Avoid NaN and -0 as consts. */
784 if (LJ_DUALNUM) {
785 int64_t i64;
786 int32_t k;
787 if (lj_num2int_check(n, i64, k)) {
788 setintV(&e1->u.nval, k);
789 return 1;
790 }
791 }
792 setnumV(&e1->u.nval, n);
793 return 1;
794}
795
796/* Emit arithmetic operator. */
797static void bcemit_arith(FuncState *fs, BinOpr opr, ExpDesc *e1, ExpDesc *e2)
798{
799 BCReg rb, rc, t;
800 uint32_t op;
801 if (foldarith(opr, e1, e2))
802 return;
803 if (opr == OPR_POW) {
804 op = BC_POW;
805 rc = expr_toanyreg(fs, e2);
806 rb = expr_toanyreg(fs, e1);
807 } else {
808 op = opr-OPR_ADD+BC_ADDVV;
809 /* Must discharge 2nd operand first since VINDEXED might free regs. */
810 expr_toval(fs, e2);
811 if (expr_isnumk(e2) && (rc = const_num(fs, e2)) <= BCMAX_C)
812 op -= BC_ADDVV-BC_ADDVN;
813 else
814 rc = expr_toanyreg(fs, e2);
815 /* 1st operand discharged by bcemit_binop_left, but need KNUM/KSHORT. */
816 lj_assertFS(expr_isnumk(e1) || e1->k == VNONRELOC,
817 "bad expr type %d", e1->k);
818 expr_toval(fs, e1);
819 /* Avoid two consts to satisfy bytecode constraints. */
820 if (expr_isnumk(e1) && !expr_isnumk(e2) &&
821 (t = const_num(fs, e1)) <= BCMAX_B) {
822 rb = rc; rc = t; op -= BC_ADDVV-BC_ADDNV;
823 } else {
824 rb = expr_toanyreg(fs, e1);
825 }
826 }
827 /* Using expr_free might cause asserts if the order is wrong. */
828 if (e1->k == VNONRELOC && e1->u.s.info >= fs->nactvar) fs->freereg--;
829 if (e2->k == VNONRELOC && e2->u.s.info >= fs->nactvar) fs->freereg--;
830 e1->u.s.info = bcemit_ABC(fs, op, 0, rb, rc);
831 e1->k = VRELOCABLE;
832}
833
834/* Emit comparison operator. */
835static void bcemit_comp(FuncState *fs, BinOpr opr, ExpDesc *e1, ExpDesc *e2)
836{
837 ExpDesc *eret = e1;
838 BCIns ins;
839 expr_toval(fs, e1);
840 if (opr == OPR_EQ || opr == OPR_NE) {
841 BCOp op = opr == OPR_EQ ? BC_ISEQV : BC_ISNEV;
842 BCReg ra;
843 if (expr_isk(e1)) { e1 = e2; e2 = eret; } /* Need constant in 2nd arg. */
844 ra = expr_toanyreg(fs, e1); /* First arg must be in a reg. */
845 expr_toval(fs, e2);
846 switch (e2->k) {
847 case VKNIL: case VKFALSE: case VKTRUE:
848 ins = BCINS_AD(op+(BC_ISEQP-BC_ISEQV), ra, const_pri(e2));
849 break;
850 case VKSTR:
851 ins = BCINS_AD(op+(BC_ISEQS-BC_ISEQV), ra, const_str(fs, e2));
852 break;
853 case VKNUM:
854 ins = BCINS_AD(op+(BC_ISEQN-BC_ISEQV), ra, const_num(fs, e2));
855 break;
856 default:
857 ins = BCINS_AD(op, ra, expr_toanyreg(fs, e2));
858 break;
859 }
860 } else {
861 uint32_t op = opr-OPR_LT+BC_ISLT;
862 BCReg ra, rd;
863 if ((op-BC_ISLT) & 1) { /* GT -> LT, GE -> LE */
864 e1 = e2; e2 = eret; /* Swap operands. */
865 op = ((op-BC_ISLT)^3)+BC_ISLT;
866 expr_toval(fs, e1);
867 ra = expr_toanyreg(fs, e1);
868 rd = expr_toanyreg(fs, e2);
869 } else {
870 rd = expr_toanyreg(fs, e2);
871 ra = expr_toanyreg(fs, e1);
872 }
873 ins = BCINS_AD(op, ra, rd);
874 }
875 /* Using expr_free might cause asserts if the order is wrong. */
876 if (e1->k == VNONRELOC && e1->u.s.info >= fs->nactvar) fs->freereg--;
877 if (e2->k == VNONRELOC && e2->u.s.info >= fs->nactvar) fs->freereg--;
878 bcemit_INS(fs, ins);
879 eret->u.s.info = bcemit_jmp(fs);
880 eret->k = VJMP;
881}
882
883/* Fixup left side of binary operator. */
884static void bcemit_binop_left(FuncState *fs, BinOpr op, ExpDesc *e)
885{
886 if (op == OPR_AND) {
887 bcemit_branch_t(fs, e);
888 } else if (op == OPR_OR) {
889 bcemit_branch_f(fs, e);
890 } else if (op == OPR_CONCAT) {
891 expr_tonextreg(fs, e);
892 } else if (op == OPR_EQ || op == OPR_NE) {
893 if (!expr_isk_nojump(e)) expr_toanyreg(fs, e);
894 } else {
895 if (!expr_isnumk_nojump(e)) expr_toanyreg(fs, e);
896 }
897}
898
899/* Emit binary operator. */
900static void bcemit_binop(FuncState *fs, BinOpr op, ExpDesc *e1, ExpDesc *e2)
901{
902 if (op <= OPR_POW) {
903 bcemit_arith(fs, op, e1, e2);
904 } else if (op == OPR_AND) {
905 lj_assertFS(e1->t == NO_JMP, "jump list not closed");
906 expr_discharge(fs, e2);
907 jmp_append(fs, &e2->f, e1->f);
908 *e1 = *e2;
909 } else if (op == OPR_OR) {
910 lj_assertFS(e1->f == NO_JMP, "jump list not closed");
911 expr_discharge(fs, e2);
912 jmp_append(fs, &e2->t, e1->t);
913 *e1 = *e2;
914 } else if (op == OPR_CONCAT) {
915 expr_toval(fs, e2);
916 if (e2->k == VRELOCABLE && bc_op(*bcptr(fs, e2)) == BC_CAT) {
917 lj_assertFS(e1->u.s.info == bc_b(*bcptr(fs, e2))-1,
918 "bad CAT stack layout");
919 expr_free(fs, e1);
920 setbc_b(bcptr(fs, e2), e1->u.s.info);
921 e1->u.s.info = e2->u.s.info;
922 } else {
923 expr_tonextreg(fs, e2);
924 expr_free(fs, e2);
925 expr_free(fs, e1);
926 e1->u.s.info = bcemit_ABC(fs, BC_CAT, 0, e1->u.s.info, e2->u.s.info);
927 }
928 e1->k = VRELOCABLE;
929 } else {
930 lj_assertFS(op == OPR_NE || op == OPR_EQ ||
931 op == OPR_LT || op == OPR_GE || op == OPR_LE || op == OPR_GT,
932 "bad binop %d", op);
933 bcemit_comp(fs, op, e1, e2);
934 }
935}
936
937/* Emit unary operator. */
938static void bcemit_unop(FuncState *fs, BCOp op, ExpDesc *e)
939{
940 if (op == BC_NOT) {
941 /* Swap true and false lists. */
942 { BCPos temp = e->f; e->f = e->t; e->t = temp; }
943 jmp_dropval(fs, e->f);
944 jmp_dropval(fs, e->t);
945 expr_discharge(fs, e);
946 if (e->k == VKNIL || e->k == VKFALSE) {
947 e->k = VKTRUE;
948 return;
949 } else if (expr_isk(e) || (LJ_HASFFI && e->k == VKCDATA)) {
950 e->k = VKFALSE;
951 return;
952 } else if (e->k == VJMP) {
953 invertcond(fs, e);
954 return;
955 } else if (e->k == VRELOCABLE) {
956 bcreg_reserve(fs, 1);
957 setbc_a(bcptr(fs, e), fs->freereg-1);
958 e->u.s.info = fs->freereg-1;
959 e->k = VNONRELOC;
960 } else {
961 lj_assertFS(e->k == VNONRELOC, "bad expr type %d", e->k);
962 }
963 } else {
964 lj_assertFS(op == BC_UNM || op == BC_LEN, "bad unop %d", op);
965 if (op == BC_UNM && !expr_hasjump(e)) { /* Constant-fold negations. */
966#if LJ_HASFFI
967 if (e->k == VKCDATA) { /* Fold in-place since cdata is not interned. */
968 GCcdata *cd = cdataV(&e->u.nval);
969 uint64_t *p = (uint64_t *)cdataptr(cd);
970 if (cd->ctypeid == CTID_COMPLEX_DOUBLE)
971 p[1] ^= U64x(80000000,00000000);
972 else
973 *p = ~*p+1u;
974 return;
975 } else
976#endif
977 if (expr_isnumk(e) && !expr_numiszero(e)) { /* Avoid folding to -0. */
978 TValue *o = expr_numtv(e);
979 if (tvisint(o)) {
980 int32_t k = intV(o), negk = (int32_t)(~(uint32_t)k+1u);
981 if (k == negk)
982 setnumV(o, -(lua_Number)k);
983 else
984 setintV(o, negk);
985 return;
986 } else {
987 o->u64 ^= U64x(80000000,00000000);
988 return;
989 }
990 }
991 }
992 expr_toanyreg(fs, e);
993 }
994 expr_free(fs, e);
995 e->u.s.info = bcemit_AD(fs, op, 0, e->u.s.info);
996 e->k = VRELOCABLE;
997}
998
999/* -- Lexer support ------------------------------------------------------- */
1000
1001/* Check and consume optional token. */
1002static int lex_opt(LexState *ls, LexToken tok)
1003{
1004 if (ls->tok == tok) {
1005 lj_lex_next(ls);
1006 return 1;
1007 }
1008 return 0;
1009}
1010
1011/* Check and consume token. */
1012static void lex_check(LexState *ls, LexToken tok)
1013{
1014 if (ls->tok != tok)
1015 err_token(ls, tok);
1016 lj_lex_next(ls);
1017}
1018
1019/* Check for matching token. */
1020static void lex_match(LexState *ls, LexToken what, LexToken who, BCLine line)
1021{
1022 if (!lex_opt(ls, what)) {
1023 if (line == ls->linenumber) {
1024 err_token(ls, what);
1025 } else {
1026 const char *swhat = lj_lex_token2str(ls, what);
1027 const char *swho = lj_lex_token2str(ls, who);
1028 lj_lex_error(ls, ls->tok, LJ_ERR_XMATCH, swhat, swho, line);
1029 }
1030 }
1031}
1032
1033/* Check for string token. */
1034static GCstr *lex_str(LexState *ls)
1035{
1036 GCstr *s;
1037 if (ls->tok != TK_name && (LJ_52 || ls->tok != TK_goto))
1038 err_token(ls, TK_name);
1039 s = strV(&ls->tokval);
1040 lj_lex_next(ls);
1041 return s;
1042}
1043
1044/* -- Variable handling --------------------------------------------------- */
1045
1046#define var_get(ls, fs, i) ((ls)->vstack[(fs)->varmap[(i)]])
1047
1048/* Define a new local variable. */
1049static void var_new(LexState *ls, BCReg n, GCstr *name)
1050{
1051 FuncState *fs = ls->fs;
1052 MSize vtop = ls->vtop;
1053 checklimit(fs, fs->nactvar+n, LJ_MAX_LOCVAR, "local variables");
1054 if (LJ_UNLIKELY(vtop >= ls->sizevstack)) {
1055 if (ls->sizevstack >= LJ_MAX_VSTACK)
1056 lj_lex_error(ls, 0, LJ_ERR_XLIMC, LJ_MAX_VSTACK);
1057 lj_mem_growvec(ls->L, ls->vstack, ls->sizevstack, LJ_MAX_VSTACK, VarInfo);
1058 }
1059 lj_assertFS((uintptr_t)name < VARNAME__MAX ||
1060 lj_tab_getstr(fs->kt, name) != NULL,
1061 "unanchored variable name");
1062 /* NOBARRIER: name is anchored in fs->kt and ls->vstack is not a GCobj. */
1063 setgcref(ls->vstack[vtop].name, obj2gco(name));
1064 fs->varmap[fs->nactvar+n] = (uint16_t)vtop;
1065 ls->vtop = vtop+1;
1066}
1067
1068#define var_new_lit(ls, n, v) \
1069 var_new(ls, (n), lj_parse_keepstr(ls, "" v, sizeof(v)-1))
1070
1071#define var_new_fixed(ls, n, vn) \
1072 var_new(ls, (n), (GCstr *)(uintptr_t)(vn))
1073
1074/* Add local variables. */
1075static void var_add(LexState *ls, BCReg nvars)
1076{
1077 FuncState *fs = ls->fs;
1078 BCReg nactvar = fs->nactvar;
1079 while (nvars--) {
1080 VarInfo *v = &var_get(ls, fs, nactvar);
1081 v->startpc = fs->pc;
1082 v->slot = nactvar++;
1083 v->info = 0;
1084 }
1085 fs->nactvar = nactvar;
1086}
1087
1088/* Remove local variables. */
1089static void var_remove(LexState *ls, BCReg tolevel)
1090{
1091 FuncState *fs = ls->fs;
1092 while (fs->nactvar > tolevel)
1093 var_get(ls, fs, --fs->nactvar).endpc = fs->pc;
1094}
1095
1096/* Lookup local variable name. */
1097static BCReg var_lookup_local(FuncState *fs, GCstr *n)
1098{
1099 int i;
1100 for (i = fs->nactvar-1; i >= 0; i--) {
1101 if (n == strref(var_get(fs->ls, fs, i).name))
1102 return (BCReg)i;
1103 }
1104 return (BCReg)-1; /* Not found. */
1105}
1106
1107/* Lookup or add upvalue index. */
1108static MSize var_lookup_uv(FuncState *fs, MSize vidx, ExpDesc *e)
1109{
1110 MSize i, n = fs->nuv;
1111 for (i = 0; i < n; i++)
1112 if (fs->uvmap[i] == vidx)
1113 return i; /* Already exists. */
1114 /* Otherwise create a new one. */
1115 checklimit(fs, fs->nuv, LJ_MAX_UPVAL, "upvalues");
1116 lj_assertFS(e->k == VLOCAL || e->k == VUPVAL, "bad expr type %d", e->k);
1117 fs->uvmap[n] = (uint16_t)vidx;
1118 fs->uvtmp[n] = (uint16_t)(e->k == VLOCAL ? vidx : LJ_MAX_VSTACK+e->u.s.info);
1119 fs->nuv = n+1;
1120 return n;
1121}
1122
1123/* Forward declaration. */
1124static void fscope_uvmark(FuncState *fs, BCReg level);
1125
1126/* Recursively lookup variables in enclosing functions. */
1127static MSize var_lookup_(FuncState *fs, GCstr *name, ExpDesc *e, int first)
1128{
1129 if (fs) {
1130 BCReg reg = var_lookup_local(fs, name);
1131 if ((int32_t)reg >= 0) { /* Local in this function? */
1132 expr_init(e, VLOCAL, reg);
1133 if (!first)
1134 fscope_uvmark(fs, reg); /* Scope now has an upvalue. */
1135 return (MSize)(e->u.s.aux = (uint32_t)fs->varmap[reg]);
1136 } else {
1137 MSize vidx = var_lookup_(fs->prev, name, e, 0); /* Var in outer func? */
1138 if ((int32_t)vidx >= 0) { /* Yes, make it an upvalue here. */
1139 e->u.s.info = (uint8_t)var_lookup_uv(fs, vidx, e);
1140 e->k = VUPVAL;
1141 return vidx;
1142 }
1143 }
1144 } else { /* Not found in any function, must be a global. */
1145 expr_init(e, VGLOBAL, 0);
1146 e->u.sval = name;
1147 }
1148 return (MSize)-1; /* Global. */
1149}
1150
1151/* Lookup variable name. */
1152#define var_lookup(ls, e) \
1153 var_lookup_((ls)->fs, lex_str(ls), (e), 1)
1154
1155/* -- Goto an label handling ---------------------------------------------- */
1156
1157/* Add a new goto or label. */
1158static MSize gola_new(LexState *ls, GCstr *name, uint8_t info, BCPos pc)
1159{
1160 FuncState *fs = ls->fs;
1161 MSize vtop = ls->vtop;
1162 if (LJ_UNLIKELY(vtop >= ls->sizevstack)) {
1163 if (ls->sizevstack >= LJ_MAX_VSTACK)
1164 lj_lex_error(ls, 0, LJ_ERR_XLIMC, LJ_MAX_VSTACK);
1165 lj_mem_growvec(ls->L, ls->vstack, ls->sizevstack, LJ_MAX_VSTACK, VarInfo);
1166 }
1167 lj_assertFS(name == NAME_BREAK || lj_tab_getstr(fs->kt, name) != NULL,
1168 "unanchored label name");
1169 /* NOBARRIER: name is anchored in fs->kt and ls->vstack is not a GCobj. */
1170 setgcref(ls->vstack[vtop].name, obj2gco(name));
1171 ls->vstack[vtop].startpc = pc;
1172 ls->vstack[vtop].slot = (uint8_t)fs->nactvar;
1173 ls->vstack[vtop].info = info;
1174 ls->vtop = vtop+1;
1175 return vtop;
1176}
1177
1178#define gola_isgoto(v) ((v)->info & VSTACK_GOTO)
1179#define gola_islabel(v) ((v)->info & VSTACK_LABEL)
1180#define gola_isgotolabel(v) ((v)->info & (VSTACK_GOTO|VSTACK_LABEL))
1181
1182/* Patch goto to jump to label. */
1183static void gola_patch(LexState *ls, VarInfo *vg, VarInfo *vl)
1184{
1185 FuncState *fs = ls->fs;
1186 BCPos pc = vg->startpc;
1187 setgcrefnull(vg->name); /* Invalidate pending goto. */
1188 setbc_a(&fs->bcbase[pc].ins, vl->slot);
1189 jmp_patch(fs, pc, vl->startpc);
1190}
1191
1192/* Patch goto to close upvalues. */
1193static void gola_close(LexState *ls, VarInfo *vg)
1194{
1195 FuncState *fs = ls->fs;
1196 BCPos pc = vg->startpc;
1197 BCIns *ip = &fs->bcbase[pc].ins;
1198 lj_assertFS(gola_isgoto(vg), "expected goto");
1199 lj_assertFS(bc_op(*ip) == BC_JMP || bc_op(*ip) == BC_UCLO,
1200 "bad bytecode op %d", bc_op(*ip));
1201 setbc_a(ip, vg->slot);
1202 if (bc_op(*ip) == BC_JMP) {
1203 BCPos next = jmp_next(fs, pc);
1204 if (next != NO_JMP) jmp_patch(fs, next, pc); /* Jump to UCLO. */
1205 setbc_op(ip, BC_UCLO); /* Turn into UCLO. */
1206 setbc_j(ip, NO_JMP);
1207 }
1208}
1209
1210/* Resolve pending forward gotos for label. */
1211static void gola_resolve(LexState *ls, FuncScope *bl, MSize idx)
1212{
1213 VarInfo *vg = ls->vstack + bl->vstart;
1214 VarInfo *vl = ls->vstack + idx;
1215 for (; vg < vl; vg++)
1216 if (gcrefeq(vg->name, vl->name) && gola_isgoto(vg)) {
1217 if (vg->slot < vl->slot) {
1218 GCstr *name = strref(var_get(ls, ls->fs, vg->slot).name);
1219 lj_assertLS((uintptr_t)name >= VARNAME__MAX, "expected goto name");
1220 ls->linenumber = ls->fs->bcbase[vg->startpc].line;
1221 lj_assertLS(strref(vg->name) != NAME_BREAK, "unexpected break");
1222 lj_lex_error(ls, 0, LJ_ERR_XGSCOPE,
1223 strdata(strref(vg->name)), strdata(name));
1224 }
1225 gola_patch(ls, vg, vl);
1226 }
1227}
1228
1229/* Fixup remaining gotos and labels for scope. */
1230static void gola_fixup(LexState *ls, FuncScope *bl)
1231{
1232 VarInfo *v = ls->vstack + bl->vstart;
1233 VarInfo *ve = ls->vstack + ls->vtop;
1234 for (; v < ve; v++) {
1235 GCstr *name = strref(v->name);
1236 if (name != NULL) { /* Only consider remaining valid gotos/labels. */
1237 if (gola_islabel(v)) {
1238 VarInfo *vg;
1239 setgcrefnull(v->name); /* Invalidate label that goes out of scope. */
1240 for (vg = v+1; vg < ve; vg++) /* Resolve pending backward gotos. */
1241 if (strref(vg->name) == name && gola_isgoto(vg)) {
1242 if ((bl->flags&FSCOPE_UPVAL) && vg->slot > v->slot)
1243 gola_close(ls, vg);
1244 gola_patch(ls, vg, v);
1245 }
1246 } else if (gola_isgoto(v)) {
1247 if (bl->prev) { /* Propagate goto or break to outer scope. */
1248 bl->prev->flags |= name == NAME_BREAK ? FSCOPE_BREAK : FSCOPE_GOLA;
1249 v->slot = bl->nactvar;
1250 if ((bl->flags & FSCOPE_UPVAL))
1251 gola_close(ls, v);
1252 } else { /* No outer scope: undefined goto label or no loop. */
1253 ls->linenumber = ls->fs->bcbase[v->startpc].line;
1254 if (name == NAME_BREAK)
1255 lj_lex_error(ls, 0, LJ_ERR_XBREAK);
1256 else
1257 lj_lex_error(ls, 0, LJ_ERR_XLUNDEF, strdata(name));
1258 }
1259 }
1260 }
1261 }
1262}
1263
1264/* Find existing label. */
1265static VarInfo *gola_findlabel(LexState *ls, GCstr *name)
1266{
1267 VarInfo *v = ls->vstack + ls->fs->bl->vstart;
1268 VarInfo *ve = ls->vstack + ls->vtop;
1269 for (; v < ve; v++)
1270 if (strref(v->name) == name && gola_islabel(v))
1271 return v;
1272 return NULL;
1273}
1274
1275/* -- Scope handling ------------------------------------------------------ */
1276
1277/* Begin a scope. */
1278static void fscope_begin(FuncState *fs, FuncScope *bl, int flags)
1279{
1280 bl->nactvar = (uint8_t)fs->nactvar;
1281 bl->flags = flags;
1282 bl->vstart = fs->ls->vtop;
1283 bl->prev = fs->bl;
1284 fs->bl = bl;
1285 lj_assertFS(fs->freereg == fs->nactvar, "bad regalloc");
1286}
1287
1288/* End a scope. */
1289static void fscope_end(FuncState *fs)
1290{
1291 FuncScope *bl = fs->bl;
1292 LexState *ls = fs->ls;
1293 fs->bl = bl->prev;
1294 var_remove(ls, bl->nactvar);
1295 fs->freereg = fs->nactvar;
1296 lj_assertFS(bl->nactvar == fs->nactvar, "bad regalloc");
1297 if ((bl->flags & (FSCOPE_UPVAL|FSCOPE_NOCLOSE)) == FSCOPE_UPVAL)
1298 bcemit_AJ(fs, BC_UCLO, bl->nactvar, 0);
1299 if ((bl->flags & FSCOPE_BREAK)) {
1300 if ((bl->flags & FSCOPE_LOOP)) {
1301 MSize idx = gola_new(ls, NAME_BREAK, VSTACK_LABEL, fs->pc);
1302 ls->vtop = idx; /* Drop break label immediately. */
1303 gola_resolve(ls, bl, idx);
1304 } else { /* Need the fixup step to propagate the breaks. */
1305 gola_fixup(ls, bl);
1306 return;
1307 }
1308 }
1309 if ((bl->flags & FSCOPE_GOLA)) {
1310 gola_fixup(ls, bl);
1311 }
1312}
1313
1314/* Mark scope as having an upvalue. */
1315static void fscope_uvmark(FuncState *fs, BCReg level)
1316{
1317 FuncScope *bl;
1318 for (bl = fs->bl; bl && bl->nactvar > level; bl = bl->prev)
1319 ;
1320 if (bl)
1321 bl->flags |= FSCOPE_UPVAL;
1322}
1323
1324/* -- Function state management ------------------------------------------- */
1325
1326/* Fixup bytecode for prototype. */
1327static void fs_fixup_bc(FuncState *fs, GCproto *pt, BCIns *bc, MSize n)
1328{
1329 BCInsLine *base = fs->bcbase;
1330 MSize i;
1331 BCIns op;
1332 pt->sizebc = n;
1333 if (fs->ls->fr2 != LJ_FR2) op = BC_NOT; /* Mark non-native prototype. */
1334 else if ((fs->flags & PROTO_VARARG)) op = BC_FUNCV;
1335 else op = BC_FUNCF;
1336 bc[0] = BCINS_AD(op, fs->framesize, 0);
1337 for (i = 1; i < n; i++)
1338 bc[i] = base[i].ins;
1339}
1340
1341/* Fixup upvalues for child prototype, step #2. */
1342static void fs_fixup_uv2(FuncState *fs, GCproto *pt)
1343{
1344 VarInfo *vstack = fs->ls->vstack;
1345 uint16_t *uv = proto_uv(pt);
1346 MSize i, n = pt->sizeuv;
1347 for (i = 0; i < n; i++) {
1348 VarIndex vidx = uv[i];
1349 if (vidx >= LJ_MAX_VSTACK)
1350 uv[i] = vidx - LJ_MAX_VSTACK;
1351 else if ((vstack[vidx].info & VSTACK_VAR_RW))
1352 uv[i] = vstack[vidx].slot | PROTO_UV_LOCAL;
1353 else
1354 uv[i] = vstack[vidx].slot | PROTO_UV_LOCAL | PROTO_UV_IMMUTABLE;
1355 }
1356}
1357
1358/* Fixup constants for prototype. */
1359static void fs_fixup_k(FuncState *fs, GCproto *pt, void *kptr)
1360{
1361 GCtab *kt;
1362 TValue *array;
1363 Node *node;
1364 MSize i, hmask;
1365 checklimitgt(fs, fs->nkn, BCMAX_D+1, "constants");
1366 checklimitgt(fs, fs->nkgc, BCMAX_D+1, "constants");
1367 setmref(pt->k, kptr);
1368 pt->sizekn = fs->nkn;
1369 pt->sizekgc = fs->nkgc;
1370 kt = fs->kt;
1371 array = tvref(kt->array);
1372 for (i = 0; i < kt->asize; i++)
1373 if (tvhaskslot(&array[i])) {
1374 TValue *tv = &((TValue *)kptr)[tvkslot(&array[i])];
1375 if (LJ_DUALNUM)
1376 setintV(tv, (int32_t)i);
1377 else
1378 setnumV(tv, (lua_Number)i);
1379 }
1380 node = noderef(kt->node);
1381 hmask = kt->hmask;
1382 for (i = 0; i <= hmask; i++) {
1383 Node *n = &node[i];
1384 if (tvhaskslot(&n->val)) {
1385 ptrdiff_t kidx = (ptrdiff_t)tvkslot(&n->val);
1386 lj_assertFS(!tvisint(&n->key), "unexpected integer key");
1387 if (tvisnum(&n->key)) {
1388 TValue *tv = &((TValue *)kptr)[kidx];
1389 if (LJ_DUALNUM) {
1390 int64_t i64;
1391 int32_t k;
1392 lj_assertFS(!tvismzero(&n->key), "unexpected -0 key");
1393 if (lj_num2int_check(numV(&n->key), i64, k))
1394 setintV(tv, k);
1395 else
1396 *tv = n->key;
1397 } else {
1398 *tv = n->key;
1399 }
1400 } else {
1401 GCobj *o = gcV(&n->key);
1402 setgcref(((GCRef *)kptr)[~kidx], o);
1403 lj_gc_objbarrier(fs->L, pt, o);
1404 if (tvisproto(&n->key))
1405 fs_fixup_uv2(fs, gco2pt(o));
1406 }
1407 }
1408 }
1409}
1410
1411/* Fixup upvalues for prototype, step #1. */
1412static void fs_fixup_uv1(FuncState *fs, GCproto *pt, uint16_t *uv)
1413{
1414 setmref(pt->uv, uv);
1415 pt->sizeuv = fs->nuv;
1416 memcpy(uv, fs->uvtmp, fs->nuv*sizeof(VarIndex));
1417}
1418
1419#ifndef LUAJIT_DISABLE_DEBUGINFO
1420/* Prepare lineinfo for prototype. */
1421static size_t fs_prep_line(FuncState *fs, BCLine numline)
1422{
1423 return (fs->pc-1) << (numline < 256 ? 0 : numline < 65536 ? 1 : 2);
1424}
1425
1426/* Fixup lineinfo for prototype. */
1427static void fs_fixup_line(FuncState *fs, GCproto *pt,
1428 void *lineinfo, BCLine numline)
1429{
1430 BCInsLine *base = fs->bcbase + 1;
1431 BCLine first = fs->linedefined;
1432 MSize i = 0, n = fs->pc-1;
1433 pt->firstline = fs->linedefined;
1434 pt->numline = numline;
1435 setmref(pt->lineinfo, lineinfo);
1436 if (LJ_LIKELY(numline < 256)) {
1437 uint8_t *li = (uint8_t *)lineinfo;
1438 do {
1439 BCLine delta = base[i].line - first;
1440 lj_assertFS(delta >= 0 && delta < 256, "bad line delta");
1441 li[i] = (uint8_t)delta;
1442 } while (++i < n);
1443 } else if (LJ_LIKELY(numline < 65536)) {
1444 uint16_t *li = (uint16_t *)lineinfo;
1445 do {
1446 BCLine delta = base[i].line - first;
1447 lj_assertFS(delta >= 0 && delta < 65536, "bad line delta");
1448 li[i] = (uint16_t)delta;
1449 } while (++i < n);
1450 } else {
1451 uint32_t *li = (uint32_t *)lineinfo;
1452 do {
1453 BCLine delta = base[i].line - first;
1454 lj_assertFS(delta >= 0, "bad line delta");
1455 li[i] = (uint32_t)delta;
1456 } while (++i < n);
1457 }
1458}
1459
1460/* Prepare variable info for prototype. */
1461static size_t fs_prep_var(LexState *ls, FuncState *fs, size_t *ofsvar)
1462{
1463 VarInfo *vs =ls->vstack, *ve;
1464 MSize i, n;
1465 BCPos lastpc;
1466 lj_buf_reset(&ls->sb); /* Copy to temp. string buffer. */
1467 /* Store upvalue names. */
1468 for (i = 0, n = fs->nuv; i < n; i++) {
1469 GCstr *s = strref(vs[fs->uvmap[i]].name);
1470 MSize len = s->len+1;
1471 char *p = lj_buf_more(&ls->sb, len);
1472 p = lj_buf_wmem(p, strdata(s), len);
1473 ls->sb.w = p;
1474 }
1475 *ofsvar = sbuflen(&ls->sb);
1476 lastpc = 0;
1477 /* Store local variable names and compressed ranges. */
1478 for (ve = vs + ls->vtop, vs += fs->vbase; vs < ve; vs++) {
1479 if (!gola_isgotolabel(vs)) {
1480 GCstr *s = strref(vs->name);
1481 BCPos startpc;
1482 char *p;
1483 if ((uintptr_t)s < VARNAME__MAX) {
1484 p = lj_buf_more(&ls->sb, 1 + 2*5);
1485 *p++ = (char)(uintptr_t)s;
1486 } else {
1487 MSize len = s->len+1;
1488 p = lj_buf_more(&ls->sb, len + 2*5);
1489 p = lj_buf_wmem(p, strdata(s), len);
1490 }
1491 startpc = vs->startpc;
1492 p = lj_strfmt_wuleb128(p, startpc-lastpc);
1493 p = lj_strfmt_wuleb128(p, vs->endpc-startpc);
1494 ls->sb.w = p;
1495 lastpc = startpc;
1496 }
1497 }
1498 lj_buf_putb(&ls->sb, '\0'); /* Terminator for varinfo. */
1499 return sbuflen(&ls->sb);
1500}
1501
1502/* Fixup variable info for prototype. */
1503static void fs_fixup_var(LexState *ls, GCproto *pt, uint8_t *p, size_t ofsvar)
1504{
1505 setmref(pt->uvinfo, p);
1506 setmref(pt->varinfo, (char *)p + ofsvar);
1507 memcpy(p, ls->sb.b, sbuflen(&ls->sb)); /* Copy from temp. buffer. */
1508}
1509#else
1510
1511/* Initialize with empty debug info, if disabled. */
1512#define fs_prep_line(fs, numline) (UNUSED(numline), 0)
1513#define fs_fixup_line(fs, pt, li, numline) \
1514 pt->firstline = pt->numline = 0, setmref((pt)->lineinfo, NULL)
1515#define fs_prep_var(ls, fs, ofsvar) (UNUSED(ofsvar), 0)
1516#define fs_fixup_var(ls, pt, p, ofsvar) \
1517 setmref((pt)->uvinfo, NULL), setmref((pt)->varinfo, NULL)
1518
1519#endif
1520
1521/* Fixup return instruction for prototype. */
1522static void fs_fixup_ret(FuncState *fs)
1523{
1524 BCPos lastpc = fs->pc;
1525 if (lastpc <= fs->lasttarget || !bc_isret_or_tail(bc_op(fs->bcbase[lastpc-1].ins))) {
1526 if ((fs->bl->flags & FSCOPE_UPVAL))
1527 bcemit_AJ(fs, BC_UCLO, 0, 0);
1528 bcemit_AD(fs, BC_RET0, 0, 1); /* Need final return. */
1529 }
1530 fs->bl->flags |= FSCOPE_NOCLOSE; /* Handled above. */
1531 fscope_end(fs);
1532 lj_assertFS(fs->bl == NULL, "bad scope nesting");
1533 /* May need to fixup returns encoded before first function was created. */
1534 if (fs->flags & PROTO_FIXUP_RETURN) {
1535 BCPos pc;
1536 for (pc = 1; pc < lastpc; pc++) {
1537 BCIns ins = fs->bcbase[pc].ins;
1538 BCPos offset;
1539 switch (bc_op(ins)) {
1540 case BC_CALLMT: case BC_CALLT:
1541 case BC_RETM: case BC_RET: case BC_RET0: case BC_RET1:
1542 offset = bcemit_INS(fs, ins); /* Copy original instruction. */
1543 fs->bcbase[offset].line = fs->bcbase[pc].line;
1544 offset = offset-(pc+1)+BCBIAS_J;
1545 if (offset > BCMAX_D)
1546 err_syntax(fs->ls, LJ_ERR_XFIXUP);
1547 /* Replace with UCLO plus branch. */
1548 fs->bcbase[pc].ins = BCINS_AD(BC_UCLO, 0, offset);
1549 break;
1550 case BC_FNEW:
1551 return; /* We're done. */
1552 default:
1553 break;
1554 }
1555 }
1556 }
1557}
1558
1559/* Finish a FuncState and return the new prototype. */
1560static GCproto *fs_finish(LexState *ls, BCLine line)
1561{
1562 lua_State *L = ls->L;
1563 FuncState *fs = ls->fs;
1564 BCLine numline = line - fs->linedefined;
1565 size_t sizept, ofsk, ofsuv, ofsli, ofsdbg, ofsvar;
1566 GCproto *pt;
1567
1568 /* Apply final fixups. */
1569 fs_fixup_ret(fs);
1570
1571 /* Calculate total size of prototype including all colocated arrays. */
1572 sizept = sizeof(GCproto) + fs->pc*sizeof(BCIns) + fs->nkgc*sizeof(GCRef);
1573 sizept = (sizept + sizeof(TValue)-1) & ~(sizeof(TValue)-1);
1574 ofsk = sizept; sizept += fs->nkn*sizeof(TValue);
1575 ofsuv = sizept; sizept += ((fs->nuv+1)&~1)*2;
1576 ofsli = sizept; sizept += fs_prep_line(fs, numline);
1577 ofsdbg = sizept; sizept += fs_prep_var(ls, fs, &ofsvar);
1578
1579 /* Allocate prototype and initialize its fields. */
1580 pt = (GCproto *)lj_mem_newgco(L, (MSize)sizept);
1581 pt->gct = ~LJ_TPROTO;
1582 pt->sizept = (MSize)sizept;
1583 pt->trace = 0;
1584 pt->flags = (uint8_t)(fs->flags & ~(PROTO_HAS_RETURN|PROTO_FIXUP_RETURN));
1585 pt->numparams = fs->numparams;
1586 pt->framesize = fs->framesize;
1587 setgcref(pt->chunkname, obj2gco(ls->chunkname));
1588
1589 /* Close potentially uninitialized gap between bc and kgc. */
1590 *(uint32_t *)((char *)pt + ofsk - sizeof(GCRef)*(fs->nkgc+1)) = 0;
1591 fs_fixup_bc(fs, pt, (BCIns *)((char *)pt + sizeof(GCproto)), fs->pc);
1592 fs_fixup_k(fs, pt, (void *)((char *)pt + ofsk));
1593 fs_fixup_uv1(fs, pt, (uint16_t *)((char *)pt + ofsuv));
1594 fs_fixup_line(fs, pt, (void *)((char *)pt + ofsli), numline);
1595 fs_fixup_var(ls, pt, (uint8_t *)((char *)pt + ofsdbg), ofsvar);
1596
1597 lj_vmevent_send(G(L), BC,
1598 setprotoV(V, V->top++, pt);
1599 );
1600
1601 L->top--; /* Pop table of constants. */
1602 ls->vtop = fs->vbase; /* Reset variable stack. */
1603 ls->fs = fs->prev;
1604 lj_assertL(ls->fs != NULL || ls->tok == TK_eof, "bad parser state");
1605 return pt;
1606}
1607
1608/* Initialize a new FuncState. */
1609static void fs_init(LexState *ls, FuncState *fs)
1610{
1611 lua_State *L = ls->L;
1612 fs->prev = ls->fs; ls->fs = fs; /* Append to list. */
1613 fs->ls = ls;
1614 fs->vbase = ls->vtop;
1615 fs->L = L;
1616 fs->pc = 0;
1617 fs->lasttarget = 0;
1618 fs->jpc = NO_JMP;
1619 fs->freereg = 0;
1620 fs->nkgc = 0;
1621 fs->nkn = 0;
1622 fs->nactvar = 0;
1623 fs->nuv = 0;
1624 fs->bl = NULL;
1625 fs->flags = 0;
1626 fs->framesize = 1; /* Minimum frame size. */
1627 fs->kt = lj_tab_new(L, 0, 0);
1628 /* Anchor table of constants in stack to avoid being collected. */
1629 settabV(L, L->top, fs->kt);
1630 incr_top(L);
1631}
1632
1633/* -- Expressions --------------------------------------------------------- */
1634
1635/* Forward declaration. */
1636static void expr(LexState *ls, ExpDesc *v);
1637
1638/* Return string expression. */
1639static void expr_str(LexState *ls, ExpDesc *e)
1640{
1641 expr_init(e, VKSTR, 0);
1642 e->u.sval = lex_str(ls);
1643}
1644
1645/* Return index expression. */
1646static void expr_index(FuncState *fs, ExpDesc *t, ExpDesc *e)
1647{
1648 /* Already called: expr_toval(fs, e). */
1649 t->k = VINDEXED;
1650 if (expr_isnumk(e)) {
1651#if LJ_DUALNUM
1652 if (tvisint(expr_numtv(e))) {
1653 int32_t k = intV(expr_numtv(e));
1654 if (checku8(k)) {
1655 t->u.s.aux = BCMAX_C+1+(uint32_t)k; /* 256..511: const byte key */
1656 return;
1657 }
1658 }
1659#else
1660 int64_t i64;
1661 int32_t k;
1662 if (lj_num2int_cond(expr_numberV(e), i64, k, checku8((int32_t)i64))) {
1663 t->u.s.aux = BCMAX_C+1+(uint32_t)k; /* 256..511: const byte key */
1664 return;
1665 }
1666#endif
1667 } else if (expr_isstrk(e)) {
1668 BCReg idx = const_str(fs, e);
1669 if (idx <= BCMAX_C) {
1670 t->u.s.aux = ~idx; /* -256..-1: const string key */
1671 return;
1672 }
1673 }
1674 t->u.s.aux = expr_toanyreg(fs, e); /* 0..255: register */
1675}
1676
1677/* Parse index expression with named field. */
1678static void expr_field(LexState *ls, ExpDesc *v)
1679{
1680 FuncState *fs = ls->fs;
1681 ExpDesc key;
1682 expr_toanyreg(fs, v);
1683 lj_lex_next(ls); /* Skip dot or colon. */
1684 expr_str(ls, &key);
1685 expr_index(fs, v, &key);
1686}
1687
1688/* Parse index expression with brackets. */
1689static void expr_bracket(LexState *ls, ExpDesc *v)
1690{
1691 lj_lex_next(ls); /* Skip '['. */
1692 expr(ls, v);
1693 expr_toval(ls->fs, v);
1694 lex_check(ls, ']');
1695}
1696
1697/* Get value of constant expression. */
1698static void expr_kvalue(FuncState *fs, TValue *v, ExpDesc *e)
1699{
1700 UNUSED(fs);
1701 if (e->k <= VKTRUE) {
1702 setpriV(v, ~(uint32_t)e->k);
1703 } else if (e->k == VKSTR) {
1704 setgcVraw(v, obj2gco(e->u.sval), LJ_TSTR);
1705 } else {
1706 lj_assertFS(tvisnumber(expr_numtv(e)), "bad number constant");
1707 *v = *expr_numtv(e);
1708 }
1709}
1710
1711/* Parse table constructor expression. */
1712static void expr_table(LexState *ls, ExpDesc *e)
1713{
1714 FuncState *fs = ls->fs;
1715 BCLine line = ls->linenumber;
1716 GCtab *t = NULL;
1717 int vcall = 0, needarr = 0;
1718 uint32_t narr = 1; /* First array index. */
1719 uint32_t nhash = 0; /* Number of hash entries. */
1720 BCReg freg = fs->freereg;
1721 BCPos pc = bcemit_AD(fs, BC_TNEW, freg, 0);
1722 expr_init(e, VNONRELOC, freg);
1723 bcreg_reserve(fs, 1);
1724 freg++;
1725 lex_check(ls, '{');
1726 while (ls->tok != '}') {
1727 ExpDesc key, val;
1728 vcall = 0;
1729 if (ls->tok == '[') {
1730 expr_bracket(ls, &key); /* Already calls expr_toval. */
1731 if (!expr_isk(&key)) expr_index(fs, e, &key);
1732 if (expr_isnumk(&key) && expr_numiszero(&key)) needarr = 1; else nhash++;
1733 lex_check(ls, '=');
1734 } else if ((ls->tok == TK_name || (!LJ_52 && ls->tok == TK_goto)) &&
1735 lj_lex_lookahead(ls) == '=') {
1736 expr_str(ls, &key);
1737 lex_check(ls, '=');
1738 nhash++;
1739 } else {
1740 expr_init(&key, VKNUM, 0);
1741 setintV(&key.u.nval, (int)narr);
1742 narr++;
1743 needarr = vcall = 1;
1744 }
1745 expr(ls, &val);
1746 if (expr_isk(&key) && key.k != VKNIL &&
1747 (key.k == VKSTR || expr_isk_nojump(&val))) {
1748 TValue k, *v;
1749 if (!t) { /* Create template table on demand. */
1750 BCReg kidx;
1751 t = lj_tab_new(fs->L, needarr ? narr : 0, hsize2hbits(nhash));
1752 kidx = const_gc(fs, obj2gco(t), LJ_TTAB);
1753 fs->bcbase[pc].ins = BCINS_AD(BC_TDUP, freg-1, kidx);
1754 }
1755 vcall = 0;
1756 expr_kvalue(fs, &k, &key);
1757 v = lj_tab_set(fs->L, t, &k);
1758 lj_gc_anybarriert(fs->L, t);
1759 if (expr_isk_nojump(&val)) { /* Add const key/value to template table. */
1760 expr_kvalue(fs, v, &val);
1761 /* Mark nil value with table value itself to preserve the key. */
1762 if (key.k == VKSTR && tvisnil(v)) settabV(fs->L, v, t);
1763 } else { /* Preserve the key for the following non-const store. */
1764 settabV(fs->L, v, t);
1765 goto nonconst;
1766 }
1767 } else {
1768 nonconst:
1769 if (val.k != VCALL) { expr_toanyreg(fs, &val); vcall = 0; }
1770 if (expr_isk(&key)) expr_index(fs, e, &key);
1771 bcemit_store(fs, e, &val);
1772 }
1773 fs->freereg = freg;
1774 if (!lex_opt(ls, ',') && !lex_opt(ls, ';')) break;
1775 }
1776 lex_match(ls, '}', '{', line);
1777 if (vcall) {
1778 BCInsLine *ilp = &fs->bcbase[fs->pc-1];
1779 ExpDesc en;
1780 lj_assertFS(bc_a(ilp->ins) == freg &&
1781 bc_op(ilp->ins) == (narr > 256 ? BC_TSETV : BC_TSETB),
1782 "bad CALL code generation");
1783 expr_init(&en, VKNUM, 0);
1784 en.u.nval.u32.lo = narr-1;
1785 en.u.nval.u32.hi = 0x43300000; /* Biased integer to avoid denormals. */
1786 if (narr > 256) { fs->pc--; ilp--; }
1787 ilp->ins = BCINS_AD(BC_TSETM, freg, const_num(fs, &en));
1788 setbc_b(&ilp[-1].ins, 0);
1789 }
1790 if (pc == fs->pc-1) { /* Make expr relocable if possible. */
1791 e->u.s.info = pc;
1792 fs->freereg--;
1793 e->k = VRELOCABLE;
1794 } else {
1795 e->k = VNONRELOC; /* May have been changed by expr_index. */
1796 }
1797 if (!t) { /* Construct TNEW RD: hhhhhaaaaaaaaaaa. */
1798 BCIns *ip = &fs->bcbase[pc].ins;
1799 if (!needarr) narr = 0;
1800 else if (narr < 3) narr = 3;
1801 else if (narr > 0x7ff) narr = 0x7ff;
1802 setbc_d(ip, narr|(hsize2hbits(nhash)<<11));
1803 } else {
1804 if (needarr && t->asize < narr)
1805 lj_tab_reasize(fs->L, t, narr-1);
1806 lj_gc_check(fs->L);
1807 }
1808}
1809
1810/* Parse function parameters. */
1811static BCReg parse_params(LexState *ls, int needself)
1812{
1813 FuncState *fs = ls->fs;
1814 BCReg nparams = 0;
1815 lex_check(ls, '(');
1816 if (needself)
1817 var_new_lit(ls, nparams++, "self");
1818 if (ls->tok != ')') {
1819 do {
1820 if (ls->tok == TK_name || (!LJ_52 && ls->tok == TK_goto)) {
1821 var_new(ls, nparams++, lex_str(ls));
1822 } else if (ls->tok == TK_dots) {
1823 lj_lex_next(ls);
1824 fs->flags |= PROTO_VARARG;
1825 break;
1826 } else {
1827 err_syntax(ls, LJ_ERR_XPARAM);
1828 }
1829 } while (lex_opt(ls, ','));
1830 }
1831 var_add(ls, nparams);
1832 lj_assertFS(fs->nactvar == nparams, "bad regalloc");
1833 bcreg_reserve(fs, nparams);
1834 lex_check(ls, ')');
1835 return nparams;
1836}
1837
1838/* Forward declaration. */
1839static void parse_chunk(LexState *ls);
1840
1841/* Parse body of a function. */
1842static void parse_body(LexState *ls, ExpDesc *e, int needself, BCLine line)
1843{
1844 FuncState fs, *pfs = ls->fs;
1845 FuncScope bl;
1846 GCproto *pt;
1847 ptrdiff_t oldbase = pfs->bcbase - ls->bcstack;
1848 fs_init(ls, &fs);
1849 fscope_begin(&fs, &bl, 0);
1850 fs.linedefined = line;
1851 fs.numparams = (uint8_t)parse_params(ls, needself);
1852 fs.bcbase = pfs->bcbase + pfs->pc;
1853 fs.bclim = pfs->bclim - pfs->pc;
1854 bcemit_AD(&fs, BC_FUNCF, 0, 0); /* Placeholder. */
1855 parse_chunk(ls);
1856 if (ls->tok != TK_end) lex_match(ls, TK_end, TK_function, line);
1857 pt = fs_finish(ls, (ls->lastline = ls->linenumber));
1858 pfs->bcbase = ls->bcstack + oldbase; /* May have been reallocated. */
1859 pfs->bclim = (BCPos)(ls->sizebcstack - oldbase);
1860 /* Store new prototype in the constant array of the parent. */
1861 expr_init(e, VRELOCABLE,
1862 bcemit_AD(pfs, BC_FNEW, 0, const_gc(pfs, obj2gco(pt), LJ_TPROTO)));
1863#if LJ_HASFFI
1864 pfs->flags |= (fs.flags & PROTO_FFI);
1865#endif
1866 if (!(pfs->flags & PROTO_CHILD)) {
1867 if (pfs->flags & PROTO_HAS_RETURN)
1868 pfs->flags |= PROTO_FIXUP_RETURN;
1869 pfs->flags |= PROTO_CHILD;
1870 }
1871 lj_lex_next(ls);
1872}
1873
1874/* Parse expression list. Last expression is left open. */
1875static BCReg expr_list(LexState *ls, ExpDesc *v)
1876{
1877 BCReg n = 1;
1878 expr(ls, v);
1879 while (lex_opt(ls, ',')) {
1880 expr_tonextreg(ls->fs, v);
1881 expr(ls, v);
1882 n++;
1883 }
1884 return n;
1885}
1886
1887/* Parse function argument list. */
1888static void parse_args(LexState *ls, ExpDesc *e)
1889{
1890 FuncState *fs = ls->fs;
1891 ExpDesc args;
1892 BCIns ins;
1893 BCReg base;
1894 BCLine line = ls->linenumber;
1895 if (ls->tok == '(') {
1896#if !LJ_52
1897 if (line != ls->lastline)
1898 err_syntax(ls, LJ_ERR_XAMBIG);
1899#endif
1900 lj_lex_next(ls);
1901 if (ls->tok == ')') { /* f(). */
1902 args.k = VVOID;
1903 } else {
1904 expr_list(ls, &args);
1905 if (args.k == VCALL) /* f(a, b, g()) or f(a, b, ...). */
1906 setbc_b(bcptr(fs, &args), 0); /* Pass on multiple results. */
1907 }
1908 lex_match(ls, ')', '(', line);
1909 } else if (ls->tok == '{') {
1910 expr_table(ls, &args);
1911 } else if (ls->tok == TK_string) {
1912 expr_init(&args, VKSTR, 0);
1913 args.u.sval = strV(&ls->tokval);
1914 lj_lex_next(ls);
1915 } else {
1916 err_syntax(ls, LJ_ERR_XFUNARG);
1917 return; /* Silence compiler. */
1918 }
1919 lj_assertFS(e->k == VNONRELOC, "bad expr type %d", e->k);
1920 base = e->u.s.info; /* Base register for call. */
1921 if (args.k == VCALL) {
1922 ins = BCINS_ABC(BC_CALLM, base, 2, args.u.s.aux - base - 1 - ls->fr2);
1923 } else {
1924 if (args.k != VVOID)
1925 expr_tonextreg(fs, &args);
1926 ins = BCINS_ABC(BC_CALL, base, 2, fs->freereg - base - ls->fr2);
1927 }
1928 expr_init(e, VCALL, bcemit_INS(fs, ins));
1929 e->u.s.aux = base;
1930 fs->bcbase[fs->pc - 1].line = line;
1931 fs->freereg = base+1; /* Leave one result by default. */
1932}
1933
1934/* Parse primary expression. */
1935static void expr_primary(LexState *ls, ExpDesc *v)
1936{
1937 FuncState *fs = ls->fs;
1938 /* Parse prefix expression. */
1939 if (ls->tok == '(') {
1940 BCLine line = ls->linenumber;
1941 lj_lex_next(ls);
1942 expr(ls, v);
1943 lex_match(ls, ')', '(', line);
1944 expr_discharge(ls->fs, v);
1945 } else if (ls->tok == TK_name || (!LJ_52 && ls->tok == TK_goto)) {
1946 var_lookup(ls, v);
1947 } else {
1948 err_syntax(ls, LJ_ERR_XSYMBOL);
1949 }
1950 for (;;) { /* Parse multiple expression suffixes. */
1951 if (ls->tok == '.') {
1952 expr_field(ls, v);
1953 } else if (ls->tok == '[') {
1954 ExpDesc key;
1955 expr_toanyreg(fs, v);
1956 expr_bracket(ls, &key);
1957 expr_index(fs, v, &key);
1958 } else if (ls->tok == ':') {
1959 ExpDesc key;
1960 lj_lex_next(ls);
1961 expr_str(ls, &key);
1962 bcemit_method(fs, v, &key);
1963 parse_args(ls, v);
1964 } else if (ls->tok == '(' || ls->tok == TK_string || ls->tok == '{') {
1965 expr_tonextreg(fs, v);
1966 if (ls->fr2) bcreg_reserve(fs, 1);
1967 parse_args(ls, v);
1968 } else {
1969 break;
1970 }
1971 }
1972}
1973
1974/* Parse simple expression. */
1975static void expr_simple(LexState *ls, ExpDesc *v)
1976{
1977 switch (ls->tok) {
1978 case TK_number:
1979 expr_init(v, (LJ_HASFFI && tviscdata(&ls->tokval)) ? VKCDATA : VKNUM, 0);
1980 copyTV(ls->L, &v->u.nval, &ls->tokval);
1981 break;
1982 case TK_string:
1983 expr_init(v, VKSTR, 0);
1984 v->u.sval = strV(&ls->tokval);
1985 break;
1986 case TK_nil:
1987 expr_init(v, VKNIL, 0);
1988 break;
1989 case TK_true:
1990 expr_init(v, VKTRUE, 0);
1991 break;
1992 case TK_false:
1993 expr_init(v, VKFALSE, 0);
1994 break;
1995 case TK_dots: { /* Vararg. */
1996 FuncState *fs = ls->fs;
1997 BCReg base;
1998 checkcond(ls, fs->flags & PROTO_VARARG, LJ_ERR_XDOTS);
1999 bcreg_reserve(fs, 1);
2000 base = fs->freereg-1;
2001 expr_init(v, VCALL, bcemit_ABC(fs, BC_VARG, base, 2, fs->numparams));
2002 v->u.s.aux = base;
2003 break;
2004 }
2005 case '{': /* Table constructor. */
2006 expr_table(ls, v);
2007 return;
2008 case TK_function:
2009 lj_lex_next(ls);
2010 parse_body(ls, v, 0, ls->linenumber);
2011 return;
2012 default:
2013 expr_primary(ls, v);
2014 return;
2015 }
2016 lj_lex_next(ls);
2017}
2018
2019/* Manage syntactic levels to avoid blowing up the stack. */
2020static void synlevel_begin(LexState *ls)
2021{
2022 if (++ls->level >= LJ_MAX_XLEVEL)
2023 lj_lex_error(ls, 0, LJ_ERR_XLEVELS);
2024}
2025
2026#define synlevel_end(ls) ((ls)->level--)
2027
2028/* Convert token to binary operator. */
2029static BinOpr token2binop(LexToken tok)
2030{
2031 switch (tok) {
2032 case '+': return OPR_ADD;
2033 case '-': return OPR_SUB;
2034 case '*': return OPR_MUL;
2035 case '/': return OPR_DIV;
2036 case '%': return OPR_MOD;
2037 case '^': return OPR_POW;
2038 case TK_concat: return OPR_CONCAT;
2039 case TK_ne: return OPR_NE;
2040 case TK_eq: return OPR_EQ;
2041 case '<': return OPR_LT;
2042 case TK_le: return OPR_LE;
2043 case '>': return OPR_GT;
2044 case TK_ge: return OPR_GE;
2045 case TK_and: return OPR_AND;
2046 case TK_or: return OPR_OR;
2047 default: return OPR_NOBINOPR;
2048 }
2049}
2050
2051/* Priorities for each binary operator. ORDER OPR. */
2052static const struct {
2053 uint8_t left; /* Left priority. */
2054 uint8_t right; /* Right priority. */
2055} priority[] = {
2056 {6,6}, {6,6}, {7,7}, {7,7}, {7,7}, /* ADD SUB MUL DIV MOD */
2057 {10,9}, {5,4}, /* POW CONCAT (right associative) */
2058 {3,3}, {3,3}, /* EQ NE */
2059 {3,3}, {3,3}, {3,3}, {3,3}, /* LT GE GT LE */
2060 {2,2}, {1,1} /* AND OR */
2061};
2062
2063#define UNARY_PRIORITY 8 /* Priority for unary operators. */
2064
2065/* Forward declaration. */
2066static BinOpr expr_binop(LexState *ls, ExpDesc *v, uint32_t limit);
2067
2068/* Parse unary expression. */
2069static void expr_unop(LexState *ls, ExpDesc *v)
2070{
2071 BCOp op;
2072 if (ls->tok == TK_not) {
2073 op = BC_NOT;
2074 } else if (ls->tok == '-') {
2075 op = BC_UNM;
2076 } else if (ls->tok == '#') {
2077 op = BC_LEN;
2078 } else {
2079 expr_simple(ls, v);
2080 return;
2081 }
2082 lj_lex_next(ls);
2083 expr_binop(ls, v, UNARY_PRIORITY);
2084 bcemit_unop(ls->fs, op, v);
2085}
2086
2087/* Parse binary expressions with priority higher than the limit. */
2088static BinOpr expr_binop(LexState *ls, ExpDesc *v, uint32_t limit)
2089{
2090 BinOpr op;
2091 synlevel_begin(ls);
2092 expr_unop(ls, v);
2093 op = token2binop(ls->tok);
2094 while (op != OPR_NOBINOPR && priority[op].left > limit) {
2095 ExpDesc v2;
2096 BinOpr nextop;
2097 lj_lex_next(ls);
2098 bcemit_binop_left(ls->fs, op, v);
2099 /* Parse binary expression with higher priority. */
2100 nextop = expr_binop(ls, &v2, priority[op].right);
2101 bcemit_binop(ls->fs, op, v, &v2);
2102 op = nextop;
2103 }
2104 synlevel_end(ls);
2105 return op; /* Return unconsumed binary operator (if any). */
2106}
2107
2108/* Parse expression. */
2109static void expr(LexState *ls, ExpDesc *v)
2110{
2111 expr_binop(ls, v, 0); /* Priority 0: parse whole expression. */
2112}
2113
2114/* Assign expression to the next register. */
2115static void expr_next(LexState *ls)
2116{
2117 ExpDesc e;
2118 expr(ls, &e);
2119 expr_tonextreg(ls->fs, &e);
2120}
2121
2122/* Parse conditional expression. */
2123static BCPos expr_cond(LexState *ls)
2124{
2125 ExpDesc v;
2126 expr(ls, &v);
2127 if (v.k == VKNIL) v.k = VKFALSE;
2128 bcemit_branch_t(ls->fs, &v);
2129 return v.f;
2130}
2131
2132/* -- Assignments --------------------------------------------------------- */
2133
2134/* List of LHS variables. */
2135typedef struct LHSVarList {
2136 ExpDesc v; /* LHS variable. */
2137 struct LHSVarList *prev; /* Link to previous LHS variable. */
2138} LHSVarList;
2139
2140/* Eliminate write-after-read hazards for local variable assignment. */
2141static void assign_hazard(LexState *ls, LHSVarList *lh, const ExpDesc *v)
2142{
2143 FuncState *fs = ls->fs;
2144 BCReg reg = v->u.s.info; /* Check against this variable. */
2145 BCReg tmp = fs->freereg; /* Rename to this temp. register (if needed). */
2146 int hazard = 0;
2147 for (; lh; lh = lh->prev) {
2148 if (lh->v.k == VINDEXED) {
2149 if (lh->v.u.s.info == reg) { /* t[i], t = 1, 2 */
2150 hazard = 1;
2151 lh->v.u.s.info = tmp;
2152 }
2153 if (lh->v.u.s.aux == reg) { /* t[i], i = 1, 2 */
2154 hazard = 1;
2155 lh->v.u.s.aux = tmp;
2156 }
2157 }
2158 }
2159 if (hazard) {
2160 bcemit_AD(fs, BC_MOV, tmp, reg); /* Rename conflicting variable. */
2161 bcreg_reserve(fs, 1);
2162 }
2163}
2164
2165/* Adjust LHS/RHS of an assignment. */
2166static void assign_adjust(LexState *ls, BCReg nvars, BCReg nexps, ExpDesc *e)
2167{
2168 FuncState *fs = ls->fs;
2169 int32_t extra = (int32_t)nvars - (int32_t)nexps;
2170 if (e->k == VCALL) {
2171 extra++; /* Compensate for the VCALL itself. */
2172 if (extra < 0) extra = 0;
2173 setbc_b(bcptr(fs, e), extra+1); /* Fixup call results. */
2174 if (extra > 1) bcreg_reserve(fs, (BCReg)extra-1);
2175 } else {
2176 if (e->k != VVOID)
2177 expr_tonextreg(fs, e); /* Close last expression. */
2178 if (extra > 0) { /* Leftover LHS are set to nil. */
2179 BCReg reg = fs->freereg;
2180 bcreg_reserve(fs, (BCReg)extra);
2181 bcemit_nil(fs, reg, (BCReg)extra);
2182 }
2183 }
2184 if (nexps > nvars)
2185 ls->fs->freereg -= nexps - nvars; /* Drop leftover regs. */
2186}
2187
2188/* Recursively parse assignment statement. */
2189static void parse_assignment(LexState *ls, LHSVarList *lh, BCReg nvars)
2190{
2191 ExpDesc e;
2192 checkcond(ls, VLOCAL <= lh->v.k && lh->v.k <= VINDEXED, LJ_ERR_XSYNTAX);
2193 if (lex_opt(ls, ',')) { /* Collect LHS list and recurse upwards. */
2194 LHSVarList vl;
2195 vl.prev = lh;
2196 expr_primary(ls, &vl.v);
2197 if (vl.v.k == VLOCAL)
2198 assign_hazard(ls, lh, &vl.v);
2199 checklimit(ls->fs, ls->level + nvars, LJ_MAX_XLEVEL, "variable names");
2200 parse_assignment(ls, &vl, nvars+1);
2201 } else { /* Parse RHS. */
2202 BCReg nexps;
2203 lex_check(ls, '=');
2204 nexps = expr_list(ls, &e);
2205 if (nexps == nvars) {
2206 if (e.k == VCALL) {
2207 if (bc_op(*bcptr(ls->fs, &e)) == BC_VARG) { /* Vararg assignment. */
2208 ls->fs->freereg--;
2209 e.k = VRELOCABLE;
2210 } else { /* Multiple call results. */
2211 e.u.s.info = e.u.s.aux; /* Base of call is not relocatable. */
2212 e.k = VNONRELOC;
2213 }
2214 }
2215 bcemit_store(ls->fs, &lh->v, &e);
2216 return;
2217 }
2218 assign_adjust(ls, nvars, nexps, &e);
2219 }
2220 /* Assign RHS to LHS and recurse downwards. */
2221 expr_init(&e, VNONRELOC, ls->fs->freereg-1);
2222 bcemit_store(ls->fs, &lh->v, &e);
2223}
2224
2225/* Parse call statement or assignment. */
2226static void parse_call_assign(LexState *ls)
2227{
2228 FuncState *fs = ls->fs;
2229 LHSVarList vl;
2230 expr_primary(ls, &vl.v);
2231 if (vl.v.k == VCALL) { /* Function call statement. */
2232 setbc_b(bcptr(fs, &vl.v), 1); /* No results. */
2233 } else { /* Start of an assignment. */
2234 vl.prev = NULL;
2235 parse_assignment(ls, &vl, 1);
2236 }
2237}
2238
2239/* Parse 'local' statement. */
2240static void parse_local(LexState *ls)
2241{
2242 if (lex_opt(ls, TK_function)) { /* Local function declaration. */
2243 ExpDesc v, b;
2244 FuncState *fs = ls->fs;
2245 var_new(ls, 0, lex_str(ls));
2246 expr_init(&v, VLOCAL, fs->freereg);
2247 v.u.s.aux = fs->varmap[fs->freereg];
2248 bcreg_reserve(fs, 1);
2249 var_add(ls, 1);
2250 parse_body(ls, &b, 0, ls->linenumber);
2251 /* bcemit_store(fs, &v, &b) without setting VSTACK_VAR_RW. */
2252 expr_free(fs, &b);
2253 expr_toreg(fs, &b, v.u.s.info);
2254 /* The upvalue is in scope, but the local is only valid after the store. */
2255 var_get(ls, fs, fs->nactvar - 1).startpc = fs->pc;
2256 } else { /* Local variable declaration. */
2257 ExpDesc e;
2258 BCReg nexps, nvars = 0;
2259 do { /* Collect LHS. */
2260 var_new(ls, nvars++, lex_str(ls));
2261 } while (lex_opt(ls, ','));
2262 if (lex_opt(ls, '=')) { /* Optional RHS. */
2263 nexps = expr_list(ls, &e);
2264 } else { /* Or implicitly set to nil. */
2265 e.k = VVOID;
2266 nexps = 0;
2267 }
2268 assign_adjust(ls, nvars, nexps, &e);
2269 var_add(ls, nvars);
2270 }
2271}
2272
2273/* Parse 'function' statement. */
2274static void parse_func(LexState *ls, BCLine line)
2275{
2276 FuncState *fs;
2277 ExpDesc v, b;
2278 int needself = 0;
2279 lj_lex_next(ls); /* Skip 'function'. */
2280 /* Parse function name. */
2281 var_lookup(ls, &v);
2282 while (ls->tok == '.') /* Multiple dot-separated fields. */
2283 expr_field(ls, &v);
2284 if (ls->tok == ':') { /* Optional colon to signify method call. */
2285 needself = 1;
2286 expr_field(ls, &v);
2287 }
2288 parse_body(ls, &b, needself, line);
2289 fs = ls->fs;
2290 bcemit_store(fs, &v, &b);
2291 fs->bcbase[fs->pc - 1].line = line; /* Set line for the store. */
2292}
2293
2294/* -- Control transfer statements ----------------------------------------- */
2295
2296/* Check for end of block. */
2297static int parse_isend(LexToken tok)
2298{
2299 switch (tok) {
2300 case TK_else: case TK_elseif: case TK_end: case TK_until: case TK_eof:
2301 return 1;
2302 default:
2303 return 0;
2304 }
2305}
2306
2307/* Parse 'return' statement. */
2308static void parse_return(LexState *ls)
2309{
2310 BCIns ins;
2311 FuncState *fs = ls->fs;
2312 lj_lex_next(ls); /* Skip 'return'. */
2313 fs->flags |= PROTO_HAS_RETURN;
2314 if (parse_isend(ls->tok) || ls->tok == ';') { /* Bare return. */
2315 ins = BCINS_AD(BC_RET0, 0, 1);
2316 } else { /* Return with one or more values. */
2317 ExpDesc e; /* Receives the _last_ expression in the list. */
2318 BCReg nret = expr_list(ls, &e);
2319 if (nret == 1) { /* Return one result. */
2320 if (e.k == VCALL) { /* Check for tail call. */
2321#ifdef LUAJIT_DISABLE_TAILCALL
2322 goto notailcall;
2323#else
2324 BCIns *ip = bcptr(fs, &e);
2325 /* It doesn't pay off to add BC_VARGT just for 'return ...'. */
2326 if (bc_op(*ip) == BC_VARG) goto notailcall;
2327 fs->pc--;
2328 ins = BCINS_AD(bc_op(*ip)-BC_CALL+BC_CALLT, bc_a(*ip), bc_c(*ip));
2329#endif
2330 } else { /* Can return the result from any register. */
2331 ins = BCINS_AD(BC_RET1, expr_toanyreg(fs, &e), 2);
2332 }
2333 } else {
2334 if (e.k == VCALL) { /* Append all results from a call. */
2335 notailcall:
2336 setbc_b(bcptr(fs, &e), 0);
2337 ins = BCINS_AD(BC_RETM, fs->nactvar, e.u.s.aux - fs->nactvar);
2338 } else {
2339 expr_tonextreg(fs, &e); /* Force contiguous registers. */
2340 ins = BCINS_AD(BC_RET, fs->nactvar, nret+1);
2341 }
2342 }
2343 }
2344 if (fs->flags & PROTO_CHILD)
2345 bcemit_AJ(fs, BC_UCLO, 0, 0); /* May need to close upvalues first. */
2346 bcemit_INS(fs, ins);
2347}
2348
2349/* Parse 'break' statement. */
2350static void parse_break(LexState *ls)
2351{
2352 ls->fs->bl->flags |= FSCOPE_BREAK;
2353 gola_new(ls, NAME_BREAK, VSTACK_GOTO, bcemit_jmp(ls->fs));
2354}
2355
2356/* Parse 'goto' statement. */
2357static void parse_goto(LexState *ls)
2358{
2359 FuncState *fs = ls->fs;
2360 GCstr *name = lex_str(ls);
2361 VarInfo *vl = gola_findlabel(ls, name);
2362 if (vl) /* Treat backwards goto within same scope like a loop. */
2363 bcemit_AJ(fs, BC_LOOP, vl->slot, -1); /* No BC range check. */
2364 fs->bl->flags |= FSCOPE_GOLA;
2365 gola_new(ls, name, VSTACK_GOTO, bcemit_jmp(fs));
2366}
2367
2368/* Parse label. */
2369static void parse_label(LexState *ls)
2370{
2371 FuncState *fs = ls->fs;
2372 GCstr *name;
2373 MSize idx;
2374 fs->lasttarget = fs->pc;
2375 fs->bl->flags |= FSCOPE_GOLA;
2376 lj_lex_next(ls); /* Skip '::'. */
2377 name = lex_str(ls);
2378 if (gola_findlabel(ls, name))
2379 lj_lex_error(ls, 0, LJ_ERR_XLDUP, strdata(name));
2380 idx = gola_new(ls, name, VSTACK_LABEL, fs->pc);
2381 lex_check(ls, TK_label);
2382 /* Recursively parse trailing statements: labels and ';' (Lua 5.2 only). */
2383 for (;;) {
2384 if (ls->tok == TK_label) {
2385 synlevel_begin(ls);
2386 parse_label(ls);
2387 synlevel_end(ls);
2388 } else if (LJ_52 && ls->tok == ';') {
2389 lj_lex_next(ls);
2390 } else {
2391 break;
2392 }
2393 }
2394 /* Trailing label is considered to be outside of scope. */
2395 if (parse_isend(ls->tok) && ls->tok != TK_until)
2396 ls->vstack[idx].slot = fs->bl->nactvar;
2397 gola_resolve(ls, fs->bl, idx);
2398}
2399
2400/* -- Blocks, loops and conditional statements ---------------------------- */
2401
2402/* Parse a block. */
2403static void parse_block(LexState *ls)
2404{
2405 FuncState *fs = ls->fs;
2406 FuncScope bl;
2407 fscope_begin(fs, &bl, 0);
2408 parse_chunk(ls);
2409 fscope_end(fs);
2410}
2411
2412/* Parse 'while' statement. */
2413static void parse_while(LexState *ls, BCLine line)
2414{
2415 FuncState *fs = ls->fs;
2416 BCPos start, loop, condexit;
2417 FuncScope bl;
2418 lj_lex_next(ls); /* Skip 'while'. */
2419 start = fs->lasttarget = fs->pc;
2420 condexit = expr_cond(ls);
2421 fscope_begin(fs, &bl, FSCOPE_LOOP);
2422 lex_check(ls, TK_do);
2423 loop = bcemit_AD(fs, BC_LOOP, fs->nactvar, 0);
2424 parse_block(ls);
2425 jmp_patch(fs, bcemit_jmp(fs), start);
2426 lex_match(ls, TK_end, TK_while, line);
2427 fscope_end(fs);
2428 jmp_tohere(fs, condexit);
2429 jmp_patchins(fs, loop, fs->pc);
2430}
2431
2432/* Parse 'repeat' statement. */
2433static void parse_repeat(LexState *ls, BCLine line)
2434{
2435 FuncState *fs = ls->fs;
2436 BCPos loop = fs->lasttarget = fs->pc;
2437 BCPos condexit;
2438 FuncScope bl1, bl2;
2439 fscope_begin(fs, &bl1, FSCOPE_LOOP); /* Breakable loop scope. */
2440 fscope_begin(fs, &bl2, 0); /* Inner scope. */
2441 lj_lex_next(ls); /* Skip 'repeat'. */
2442 bcemit_AD(fs, BC_LOOP, fs->nactvar, 0);
2443 parse_chunk(ls);
2444 lex_match(ls, TK_until, TK_repeat, line);
2445 condexit = expr_cond(ls); /* Parse condition (still inside inner scope). */
2446 if (!(bl2.flags & FSCOPE_UPVAL)) { /* No upvalues? Just end inner scope. */
2447 fscope_end(fs);
2448 } else { /* Otherwise generate: cond: UCLO+JMP out, !cond: UCLO+JMP loop. */
2449 parse_break(ls); /* Break from loop and close upvalues. */
2450 jmp_tohere(fs, condexit);
2451 fscope_end(fs); /* End inner scope and close upvalues. */
2452 condexit = bcemit_jmp(fs);
2453 }
2454 jmp_patch(fs, condexit, loop); /* Jump backwards if !cond. */
2455 jmp_patchins(fs, loop, fs->pc);
2456 fscope_end(fs); /* End loop scope. */
2457}
2458
2459/* Parse numeric 'for'. */
2460static void parse_for_num(LexState *ls, GCstr *varname, BCLine line)
2461{
2462 FuncState *fs = ls->fs;
2463 BCReg base = fs->freereg;
2464 FuncScope bl;
2465 BCPos loop, loopend;
2466 /* Hidden control variables. */
2467 var_new_fixed(ls, FORL_IDX, VARNAME_FOR_IDX);
2468 var_new_fixed(ls, FORL_STOP, VARNAME_FOR_STOP);
2469 var_new_fixed(ls, FORL_STEP, VARNAME_FOR_STEP);
2470 /* Visible copy of index variable. */
2471 var_new(ls, FORL_EXT, varname);
2472 lex_check(ls, '=');
2473 expr_next(ls);
2474 lex_check(ls, ',');
2475 expr_next(ls);
2476 if (lex_opt(ls, ',')) {
2477 expr_next(ls);
2478 } else {
2479 bcemit_AD(fs, BC_KSHORT, fs->freereg, 1); /* Default step is 1. */
2480 bcreg_reserve(fs, 1);
2481 }
2482 var_add(ls, 3); /* Hidden control variables. */
2483 lex_check(ls, TK_do);
2484 loop = bcemit_AJ(fs, BC_FORI, base, NO_JMP);
2485 fscope_begin(fs, &bl, 0); /* Scope for visible variables. */
2486 var_add(ls, 1);
2487 bcreg_reserve(fs, 1);
2488 parse_block(ls);
2489 fscope_end(fs);
2490 /* Perform loop inversion. Loop control instructions are at the end. */
2491 loopend = bcemit_AJ(fs, BC_FORL, base, NO_JMP);
2492 fs->bcbase[loopend].line = line; /* Fix line for control ins. */
2493 jmp_patchins(fs, loopend, loop+1);
2494 jmp_patchins(fs, loop, fs->pc);
2495}
2496
2497/* Try to predict whether the iterator is next() and specialize the bytecode.
2498** Detecting next() and pairs() by name is simplistic, but quite effective.
2499** The interpreter backs off if the check for the closure fails at runtime.
2500*/
2501static int predict_next(LexState *ls, FuncState *fs, BCPos pc)
2502{
2503 BCIns ins = fs->bcbase[pc].ins;
2504 GCstr *name;
2505 cTValue *o;
2506 switch (bc_op(ins)) {
2507 case BC_MOV:
2508 if (bc_d(ins) >= fs->nactvar) return 0;
2509 name = gco2str(gcref(var_get(ls, fs, bc_d(ins)).name));
2510 break;
2511 case BC_UGET:
2512 name = gco2str(gcref(ls->vstack[fs->uvmap[bc_d(ins)]].name));
2513 break;
2514 case BC_GGET:
2515 /* There's no inverse index (yet), so lookup the strings. */
2516 o = lj_tab_getstr(fs->kt, lj_str_newlit(ls->L, "pairs"));
2517 if (o && tvhaskslot(o) && tvkslot(o) == bc_d(ins))
2518 return 1;
2519 o = lj_tab_getstr(fs->kt, lj_str_newlit(ls->L, "next"));
2520 if (o && tvhaskslot(o) && tvkslot(o) == bc_d(ins))
2521 return 1;
2522 return 0;
2523 default:
2524 return 0;
2525 }
2526 return (name->len == 5 && !strcmp(strdata(name), "pairs")) ||
2527 (name->len == 4 && !strcmp(strdata(name), "next"));
2528}
2529
2530/* Parse 'for' iterator. */
2531static void parse_for_iter(LexState *ls, GCstr *indexname)
2532{
2533 FuncState *fs = ls->fs;
2534 ExpDesc e;
2535 BCReg nvars = 0;
2536 BCLine line;
2537 BCReg base = fs->freereg + 3;
2538 BCPos loop, loopend, exprpc = fs->pc;
2539 FuncScope bl;
2540 int isnext;
2541 /* Hidden control variables. */
2542 var_new_fixed(ls, nvars++, VARNAME_FOR_GEN);
2543 var_new_fixed(ls, nvars++, VARNAME_FOR_STATE);
2544 var_new_fixed(ls, nvars++, VARNAME_FOR_CTL);
2545 /* Visible variables returned from iterator. */
2546 var_new(ls, nvars++, indexname);
2547 while (lex_opt(ls, ','))
2548 var_new(ls, nvars++, lex_str(ls));
2549 lex_check(ls, TK_in);
2550 line = ls->linenumber;
2551 assign_adjust(ls, 3, expr_list(ls, &e), &e);
2552 /* The iterator needs another 3 [4] slots (func [pc] | state ctl). */
2553 bcreg_bump(fs, 3+ls->fr2);
2554 isnext = (nvars <= 5 && fs->pc > exprpc && predict_next(ls, fs, exprpc));
2555 var_add(ls, 3); /* Hidden control variables. */
2556 lex_check(ls, TK_do);
2557 loop = bcemit_AJ(fs, isnext ? BC_ISNEXT : BC_JMP, base, NO_JMP);
2558 fscope_begin(fs, &bl, 0); /* Scope for visible variables. */
2559 var_add(ls, nvars-3);
2560 bcreg_reserve(fs, nvars-3);
2561 parse_block(ls);
2562 fscope_end(fs);
2563 /* Perform loop inversion. Loop control instructions are at the end. */
2564 jmp_patchins(fs, loop, fs->pc);
2565 bcemit_ABC(fs, isnext ? BC_ITERN : BC_ITERC, base, nvars-3+1, 2+1);
2566 loopend = bcemit_AJ(fs, BC_ITERL, base, NO_JMP);
2567 fs->bcbase[loopend-1].line = line; /* Fix line for control ins. */
2568 fs->bcbase[loopend].line = line;
2569 jmp_patchins(fs, loopend, loop+1);
2570}
2571
2572/* Parse 'for' statement. */
2573static void parse_for(LexState *ls, BCLine line)
2574{
2575 FuncState *fs = ls->fs;
2576 GCstr *varname;
2577 FuncScope bl;
2578 fscope_begin(fs, &bl, FSCOPE_LOOP);
2579 lj_lex_next(ls); /* Skip 'for'. */
2580 varname = lex_str(ls); /* Get first variable name. */
2581 if (ls->tok == '=')
2582 parse_for_num(ls, varname, line);
2583 else if (ls->tok == ',' || ls->tok == TK_in)
2584 parse_for_iter(ls, varname);
2585 else
2586 err_syntax(ls, LJ_ERR_XFOR);
2587 lex_match(ls, TK_end, TK_for, line);
2588 fscope_end(fs); /* Resolve break list. */
2589}
2590
2591/* Parse condition and 'then' block. */
2592static BCPos parse_then(LexState *ls)
2593{
2594 BCPos condexit;
2595 lj_lex_next(ls); /* Skip 'if' or 'elseif'. */
2596 condexit = expr_cond(ls);
2597 lex_check(ls, TK_then);
2598 parse_block(ls);
2599 return condexit;
2600}
2601
2602/* Parse 'if' statement. */
2603static void parse_if(LexState *ls, BCLine line)
2604{
2605 FuncState *fs = ls->fs;
2606 BCPos flist;
2607 BCPos escapelist = NO_JMP;
2608 flist = parse_then(ls);
2609 while (ls->tok == TK_elseif) { /* Parse multiple 'elseif' blocks. */
2610 jmp_append(fs, &escapelist, bcemit_jmp(fs));
2611 jmp_tohere(fs, flist);
2612 flist = parse_then(ls);
2613 }
2614 if (ls->tok == TK_else) { /* Parse optional 'else' block. */
2615 jmp_append(fs, &escapelist, bcemit_jmp(fs));
2616 jmp_tohere(fs, flist);
2617 lj_lex_next(ls); /* Skip 'else'. */
2618 parse_block(ls);
2619 } else {
2620 jmp_append(fs, &escapelist, flist);
2621 }
2622 jmp_tohere(fs, escapelist);
2623 lex_match(ls, TK_end, TK_if, line);
2624}
2625
2626/* -- Parse statements ---------------------------------------------------- */
2627
2628/* Parse a statement. Returns 1 if it must be the last one in a chunk. */
2629static int parse_stmt(LexState *ls)
2630{
2631 BCLine line = ls->linenumber;
2632 switch (ls->tok) {
2633 case TK_if:
2634 parse_if(ls, line);
2635 break;
2636 case TK_while:
2637 parse_while(ls, line);
2638 break;
2639 case TK_do:
2640 lj_lex_next(ls);
2641 parse_block(ls);
2642 lex_match(ls, TK_end, TK_do, line);
2643 break;
2644 case TK_for:
2645 parse_for(ls, line);
2646 break;
2647 case TK_repeat:
2648 parse_repeat(ls, line);
2649 break;
2650 case TK_function:
2651 parse_func(ls, line);
2652 break;
2653 case TK_local:
2654 lj_lex_next(ls);
2655 parse_local(ls);
2656 break;
2657 case TK_return:
2658 parse_return(ls);
2659 return 1; /* Must be last. */
2660 case TK_break:
2661 lj_lex_next(ls);
2662 parse_break(ls);
2663 return !LJ_52; /* Must be last in Lua 5.1. */
2664#if LJ_52
2665 case ';':
2666 lj_lex_next(ls);
2667 break;
2668#endif
2669 case TK_label:
2670 parse_label(ls);
2671 break;
2672 case TK_goto:
2673 if (LJ_52 || lj_lex_lookahead(ls) == TK_name) {
2674 lj_lex_next(ls);
2675 parse_goto(ls);
2676 break;
2677 }
2678 /* fallthrough */
2679 default:
2680 parse_call_assign(ls);
2681 break;
2682 }
2683 return 0;
2684}
2685
2686/* A chunk is a list of statements optionally separated by semicolons. */
2687static void parse_chunk(LexState *ls)
2688{
2689 int islast = 0;
2690 synlevel_begin(ls);
2691 while (!islast && !parse_isend(ls->tok)) {
2692 islast = parse_stmt(ls);
2693 lex_opt(ls, ';');
2694 lj_assertLS(ls->fs->framesize >= ls->fs->freereg &&
2695 ls->fs->freereg >= ls->fs->nactvar,
2696 "bad regalloc");
2697 ls->fs->freereg = ls->fs->nactvar; /* Free registers after each stmt. */
2698 }
2699 synlevel_end(ls);
2700}
2701
2702/* Entry point of bytecode parser. */
2703GCproto *lj_parse(LexState *ls)
2704{
2705 FuncState fs;
2706 FuncScope bl;
2707 GCproto *pt;
2708 lua_State *L = ls->L;
2709#ifdef LUAJIT_DISABLE_DEBUGINFO
2710 ls->chunkname = lj_str_newlit(L, "=");
2711#else
2712 ls->chunkname = lj_str_newz(L, ls->chunkarg);
2713#endif
2714 setstrV(L, L->top, ls->chunkname); /* Anchor chunkname string. */
2715 incr_top(L);
2716 ls->level = 0;
2717 fs_init(ls, &fs);
2718 fs.linedefined = 0;
2719 fs.numparams = 0;
2720 fs.bcbase = NULL;
2721 fs.bclim = 0;
2722 fs.flags |= PROTO_VARARG; /* Main chunk is always a vararg func. */
2723 fscope_begin(&fs, &bl, 0);
2724 bcemit_AD(&fs, BC_FUNCV, 0, 0); /* Placeholder. */
2725 lj_lex_next(ls); /* Read-ahead first token. */
2726 parse_chunk(ls);
2727 if (ls->tok != TK_eof)
2728 err_token(ls, TK_eof);
2729 pt = fs_finish(ls, ls->linenumber);
2730 L->top--; /* Drop chunkname. */
2731 lj_assertL(fs.prev == NULL && ls->fs == NULL, "mismatched frame nesting");
2732 lj_assertL(pt->sizeuv == 0, "toplevel proto has upvalues");
2733 return pt;
2734}
2735