9 #include <cdsannotate.h>
10 #include <specannotation.h>
11 #include <model_memory.h>
16 This is an example about how to specify the correctness of the
17 read-copy-update synchronization mechanism.
37 bool equals(Data *ptr1, Data *ptr2) {
38 if (ptr1->data1 == ptr2->data1
39 && ptr1->data2 == ptr2->data2
40 && ptr1->data3 == ptr2->data3) {
56 @Commit_point_set: Read_Success_Point
58 Data *_Old_Data = _cur_data;
60 equals(__RET__, _Old_Data)
64 Data *res = data.load(memory_order_acquire);
67 @Commit_point_define_check: true
68 @Label: Read_Success_Point
77 @Commit_point_set: Write_Success_Point
82 void write(Data *new_data) {
84 Data *prev = data.load(memory_order_relaxed);
85 bool succ = data.compare_exchange_strong(prev, new_data,
86 memory_order_release, memory_order_relaxed);
89 @Commit_point_define_check: succ == true
90 @Label: Write_Success_Point
99 void threadA(void *arg) {
100 Data *dataA = (Data*) malloc(sizeof(Data));
107 void threadB(void *arg) {
108 Data *dataB = read();
109 printf("ThreadB data1: %d\n", dataB->data1);
110 printf("ThreadB data2: %d\n", dataB->data2);
111 printf("ThreadB data3: %d\n", dataB->data3);
114 void threadC(void *arg) {
115 Data *dataC = read();
116 printf("ThreadC data1: %d\n", dataC->data1);
117 printf("ThreadC data2: %d\n", dataC->data2);
118 printf("ThreadC data3: %d\n", dataC->data3);
121 void threadD(void *arg) {
122 Data *dataD = (Data*) malloc(sizeof(Data));
129 int user_main(int argc, char **argv) {
136 thrd_t t1, t2, t3, t4;
137 data.store(NULL, memory_order_relaxed);
138 Data *data_init = (Data*) malloc(sizeof(Data));
139 data_init->data1 = 1;
140 data_init->data2 = 2;
141 data_init->data3 = 3;
144 thrd_create(&t1, threadA, NULL);
145 thrd_create(&t2, threadB, NULL);
146 //thrd_create(&t3, threadC, NULL);
147 thrd_create(&t4, threadD, NULL);