OpenCoverage

d1_meth.c

Absolute File Name:/home/opencoverage/opencoverage/guest-scripts/libressl/src/ssl/d1_meth.c
Source codeSwitch to Preprocessed file
LineSourceCount
1/* $OpenBSD: d1_meth.c,v 1.17 2018/08/30 16:56:16 jsing Exp $ */-
2/*-
3 * DTLS implementation written by Nagendra Modadugu-
4 * (nagendra@cs.stanford.edu) for the OpenSSL project 2005.-
5 */-
6/* ====================================================================-
7 * Copyright (c) 1999-2005 The OpenSSL Project. All rights reserved.-
8 *-
9 * Redistribution and use in source and binary forms, with or without-
10 * modification, are permitted provided that the following conditions-
11 * are met:-
12 *-
13 * 1. Redistributions of source code must retain the above copyright-
14 * notice, this list of conditions and the following disclaimer.-
15 *-
16 * 2. Redistributions in binary form must reproduce the above copyright-
17 * notice, this list of conditions and the following disclaimer in-
18 * the documentation and/or other materials provided with the-
19 * distribution.-
20 *-
21 * 3. All advertising materials mentioning features or use of this-
22 * software must display the following acknowledgment:-
23 * "This product includes software developed by the OpenSSL Project-
24 * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"-
25 *-
26 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to-
27 * endorse or promote products derived from this software without-
28 * prior written permission. For written permission, please contact-
29 * openssl-core@OpenSSL.org.-
30 *-
31 * 5. Products derived from this software may not be called "OpenSSL"-
32 * nor may "OpenSSL" appear in their names without prior written-
33 * permission of the OpenSSL Project.-
34 *-
35 * 6. Redistributions of any form whatsoever must retain the following-
36 * acknowledgment:-
37 * "This product includes software developed by the OpenSSL Project-
38 * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"-
39 *-
40 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY-
41 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE-
42 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR-
43 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR-
44 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,-
45 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT-
46 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;-
47 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)-
48 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,-
49 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)-
50 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED-
51 * OF THE POSSIBILITY OF SUCH DAMAGE.-
52 * ====================================================================-
53 *-
54 * This product includes cryptographic software written by Eric Young-
55 * (eay@cryptsoft.com). This product includes software written by Tim-
56 * Hudson (tjh@cryptsoft.com).-
57 *-
58 */-
59-
60#include <stdio.h>-
61-
62#include <openssl/objects.h>-
63-
64#include "ssl_locl.h"-
65-
66static const SSL_METHOD *dtls1_get_method(int ver);-
67-
68static const SSL_METHOD_INTERNAL DTLSv1_method_internal_data = {-
69 .version = DTLS1_VERSION,-
70 .min_version = DTLS1_VERSION,-
71 .max_version = DTLS1_VERSION,-
72 .ssl_new = dtls1_new,-
73 .ssl_clear = dtls1_clear,-
74 .ssl_free = dtls1_free,-
75 .ssl_accept = ssl3_accept,-
76 .ssl_connect = ssl3_connect,-
77 .get_ssl_method = dtls1_get_method,-
78 .get_timeout = dtls1_default_timeout,-
79 .ssl_version = ssl_undefined_void_function,-
80 .ssl_renegotiate = ssl3_renegotiate,-
81 .ssl_renegotiate_check = ssl3_renegotiate_check,-
82 .ssl_get_message = dtls1_get_message,-
83 .ssl_read_bytes = dtls1_read_bytes,-
84 .ssl_write_bytes = dtls1_write_app_data_bytes,-
85 .ssl3_enc = &DTLSv1_enc_data,-
86};-
87-
88static const SSL_METHOD DTLSv1_method_data = {-
89 .ssl_dispatch_alert = dtls1_dispatch_alert,-
90 .num_ciphers = ssl3_num_ciphers,-
91 .get_cipher = dtls1_get_cipher,-
92 .get_cipher_by_char = ssl3_get_cipher_by_char,-
93 .put_cipher_by_char = ssl3_put_cipher_by_char,-
94 .internal = &DTLSv1_method_internal_data,-
95};-
96-
97const SSL_METHOD *-
98DTLSv1_method(void)-
99{-
100 return &DTLSv1_method_data;
executed 17 times by 3 tests: return &DTLSv1_method_data;
Executed by:
  • cipherstest
  • ssl_versions
  • ssltest
17
101}-
102-
103static const SSL_METHOD *-
104dtls1_get_method(int ver)-
105{-
106 if (ver == DTLS1_VERSION)
ver == 0xFEFFDescription
TRUEnever evaluated
FALSEnever evaluated
0
107 return (DTLSv1_method());
never executed: return (DTLSv1_method());
0
108 return (NULL);
never executed: return ( ((void *)0) );
0
109}-
Source codeSwitch to Preprocessed file

Generated by Squish Coco 4.2.2