summaryrefslogtreecommitdiff
path: root/cpp/src/tests/legacystore/jrnl/jtt/jrnl_instance.h
blob: 5003f39b24f2e06e3139946b98cac7d1faf394ca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/*
 *
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 *
 */

#ifndef mrg_jtt_jrnl_instance_hpp
#define mrg_jtt_jrnl_instance_hpp

#include "args.h"
#include "jrnl_init_params.h"
#include "test_case.h"

#include <boost/shared_ptr.hpp>
#include "qpid/legacystore/jrnl/cvar.h"
#include "qpid/legacystore/jrnl/data_tok.h"
#include "qpid/legacystore/jrnl/jcntl.h"
#include "qpid/legacystore/jrnl/slock.h"
#include "qpid/legacystore/jrnl/smutex.h"
#include <list>
#include <vector>

namespace mrg
{
namespace jtt
{

    class jrnl_instance : public mrg::journal::jcntl, public virtual mrg::journal::aio_callback
    {
    public:
        typedef boost::shared_ptr<jrnl_instance> shared_ptr;
        typedef boost::shared_ptr<journal::data_tok> dtok_ptr;

    private:
        jrnl_init_params::shared_ptr _jpp;
        const args* _args_ptr;
        std::vector<dtok_ptr> _dtok_master_enq_list;
        std::vector<dtok_ptr> _dtok_master_txn_list;
        std::list<journal::data_tok*> _dtok_rd_list;
        std::list<journal::data_tok*> _dtok_deq_list;
        mrg::journal::smutex _rd_aio_mutex;     ///< Mutex for read aio wait conditions
        mrg::journal::cvar _rd_aio_cv;          ///< Condition var for read aio wait conditions
        mrg::journal::smutex _wr_full_mutex;    ///< Mutex for write full conditions
        mrg::journal::cvar _wr_full_cv;         ///< Condition var for write full conditions
        mrg::journal::smutex _rd_list_mutex;    ///< Mutex for _dtok_rd_list
        mrg::journal::cvar _rd_list_cv;         ///< Condition var for _dtok_rd_list
        mrg::journal::smutex _deq_list_mutex;   ///< Mutex for _dtok_deq_list
        mrg::journal::cvar _deq_list_cv;        ///< Condition var for _dtok_deq_list
        pthread_t _enq_thread;
        pthread_t _deq_thread;
        pthread_t _read_thread;
        test_case::shared_ptr _tcp;
        test_case_result::shared_ptr _tcrp;

    public:
        jrnl_instance(const std::string& jid, const std::string& jdir,
            const std::string& base_filename,
            const u_int16_t num_jfiles = jrnl_init_params::def_num_jfiles,
            const bool ae = jrnl_init_params::def_ae,
            const u_int16_t ae_max_jfiles = jrnl_init_params::def_ae_max_jfiles,
            const u_int32_t jfsize_sblks = jrnl_init_params::def_jfsize_sblks,
            const u_int16_t wcache_num_pages = jrnl_init_params::def_wcache_num_pages,
            const u_int32_t wcache_pgsize_sblks = jrnl_init_params::def_wcache_pgsize_sblks);
        jrnl_instance(const jrnl_init_params::shared_ptr& params);
        virtual ~jrnl_instance();

        inline const jrnl_init_params::shared_ptr& params() const { return _jpp; }
        inline const std::string& jid() const { return _jpp->jid(); }

        void init_tc(test_case::shared_ptr& tcp, const args* const args_ptr) throw ();
        void run_tc() throw ();
        void tc_wait_compl() throw ();

        // AIO callbacks
        virtual void wr_aio_cb(std::vector<journal::data_tok*>& dtokl);
        virtual void rd_aio_cb(std::vector<u_int16_t>& pil);

    private:
        void run_enq() throw ();
        inline static void* run_enq(void* p)
                { static_cast<jrnl_instance*>(p)->run_enq(); return 0; }

        void run_read() throw ();
        inline static void* run_read(void* p)
                { static_cast<jrnl_instance*>(p)->run_read(); return 0; }

        void run_deq() throw ();
        inline static void* run_deq(void* p)
                { static_cast<jrnl_instance*>(p)->run_deq(); return 0; }

        void abort(const mrg::journal::data_tok* dtokp);
        void commit(const mrg::journal::data_tok* dtokp);
        void txn(const mrg::journal::data_tok* dtokp, const bool commit);
        mrg::journal::data_tok* prep_txn_dtok(const mrg::journal::data_tok* dtokp);

        void panic();

//         // static callbacks
//         static void aio_rd_callback(jcntl* journal, std::vector<u_int16_t>& pil);
//         static void aio_wr_callback(jcntl* journal, std::vector<journal::data_tok*>& dtokl);
    };

} // namespace jtt
} // namespace mrg

#endif // ifndef mrg_jtt_jrnl_instance_hpp