xref: /nrf52832-nimble/rt-thread/examples/test/fs_test.c (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /*
2*10465441SEvalZero  * File      : fs_test.c
3*10465441SEvalZero  * This file is part of RT-Thread RTOS
4*10465441SEvalZero  * COPYRIGHT (C) 2011, RT-Thread Development Team
5*10465441SEvalZero  *
6*10465441SEvalZero  * The license and distribution terms for this file may be
7*10465441SEvalZero  * found in the file LICENSE in this distribution or at
8*10465441SEvalZero  * http://openlab.rt-thread.com/license/LICENSE.
9*10465441SEvalZero  *
10*10465441SEvalZero  * Change Logs:
11*10465441SEvalZero  * Date           Author       Notes
12*10465441SEvalZero  * 2011-01-02     aozima       the first version.
13*10465441SEvalZero  * 2011-03-17     aozima       fix some bug.
14*10465441SEvalZero  * 2011-03-18     aozima       to dynamic thread.
15*10465441SEvalZero  */
16*10465441SEvalZero 
17*10465441SEvalZero #include <rtthread.h>
18*10465441SEvalZero #include <dfs_posix.h>
19*10465441SEvalZero 
20*10465441SEvalZero static rt_uint32_t stop_flag = 0;
21*10465441SEvalZero static rt_thread_t fsrw1_thread = RT_NULL;
22*10465441SEvalZero static rt_thread_t fsrw2_thread = RT_NULL;
23*10465441SEvalZero 
24*10465441SEvalZero #define fsrw1_fn                   "/test1.dat"
25*10465441SEvalZero #define fsrw1_data_len             120               /* Less than 256 */
fsrw1_thread_entry(void * parameter)26*10465441SEvalZero static void fsrw1_thread_entry(void* parameter)
27*10465441SEvalZero {
28*10465441SEvalZero     int fd;
29*10465441SEvalZero     int index,length;
30*10465441SEvalZero     rt_uint32_t round;
31*10465441SEvalZero     rt_uint32_t tick_start,tick_end,read_speed,write_speed;
32*10465441SEvalZero 
33*10465441SEvalZero     static rt_uint8_t write_data1[fsrw1_data_len];
34*10465441SEvalZero     static rt_uint8_t read_data1[fsrw1_data_len];
35*10465441SEvalZero 
36*10465441SEvalZero     round = 1;
37*10465441SEvalZero 
38*10465441SEvalZero     while(1)
39*10465441SEvalZero     {
40*10465441SEvalZero         if( stop_flag )
41*10465441SEvalZero         {
42*10465441SEvalZero             rt_kprintf("thread fsrw2 error,thread fsrw1 quit!\r\n");
43*10465441SEvalZero             fsrw1_thread = RT_NULL;
44*10465441SEvalZero             stop_flag = 0;
45*10465441SEvalZero             return;
46*10465441SEvalZero         }
47*10465441SEvalZero 
48*10465441SEvalZero         /* creat file */
49*10465441SEvalZero         fd = open(fsrw1_fn, O_WRONLY | O_CREAT | O_TRUNC, 0);
50*10465441SEvalZero         if (fd < 0)
51*10465441SEvalZero         {
52*10465441SEvalZero             rt_kprintf("fsrw1 open file for write failed\n");
53*10465441SEvalZero             stop_flag = 1;
54*10465441SEvalZero             fsrw1_thread = RT_NULL;
55*10465441SEvalZero             return;
56*10465441SEvalZero         }
57*10465441SEvalZero 
58*10465441SEvalZero         /* plan write data */
59*10465441SEvalZero         for (index = 0; index < fsrw1_data_len; index ++)
60*10465441SEvalZero         {
61*10465441SEvalZero             write_data1[index] = index;
62*10465441SEvalZero         }
63*10465441SEvalZero 
64*10465441SEvalZero         /* write 8000 times */
65*10465441SEvalZero         tick_start = rt_tick_get();
66*10465441SEvalZero         for(index=0; index<8000; index++)
67*10465441SEvalZero         {
68*10465441SEvalZero             length = write(fd, write_data1, fsrw1_data_len);
69*10465441SEvalZero             if (length != fsrw1_data_len)
70*10465441SEvalZero             {
71*10465441SEvalZero                 rt_kprintf("fsrw1 write data failed\n");
72*10465441SEvalZero                 close(fd);
73*10465441SEvalZero                 fsrw1_thread = RT_NULL;
74*10465441SEvalZero                 stop_flag = 1;
75*10465441SEvalZero                 return;
76*10465441SEvalZero             }
77*10465441SEvalZero         }
78*10465441SEvalZero         tick_end = rt_tick_get();
79*10465441SEvalZero         write_speed = fsrw1_data_len*8000UL*RT_TICK_PER_SECOND/(tick_end-tick_start);
80*10465441SEvalZero 
81*10465441SEvalZero         /* close file */
82*10465441SEvalZero         close(fd);
83*10465441SEvalZero 
84*10465441SEvalZero         /* open file read only */
85*10465441SEvalZero         fd = open(fsrw1_fn, O_RDONLY, 0);
86*10465441SEvalZero         if (fd < 0)
87*10465441SEvalZero         {
88*10465441SEvalZero             rt_kprintf("fsrw1 open file for read failed\n");
89*10465441SEvalZero             stop_flag = 1;
90*10465441SEvalZero             fsrw1_thread = RT_NULL;
91*10465441SEvalZero             return;
92*10465441SEvalZero         }
93*10465441SEvalZero 
94*10465441SEvalZero         /* verify data */
95*10465441SEvalZero         tick_start = rt_tick_get();
96*10465441SEvalZero         for(index=0; index<8000; index++)
97*10465441SEvalZero         {
98*10465441SEvalZero             rt_uint32_t i;
99*10465441SEvalZero 
100*10465441SEvalZero             length = read(fd, read_data1, fsrw1_data_len);
101*10465441SEvalZero             if (length != fsrw1_data_len)
102*10465441SEvalZero             {
103*10465441SEvalZero                 rt_kprintf("fsrw1 read file failed\r\n");
104*10465441SEvalZero                 close(fd);
105*10465441SEvalZero                 stop_flag = 1;
106*10465441SEvalZero                 fsrw1_thread = RT_NULL;
107*10465441SEvalZero                 return;
108*10465441SEvalZero             }
109*10465441SEvalZero             for(i=0; i<fsrw1_data_len; i++)
110*10465441SEvalZero             {
111*10465441SEvalZero                 if( read_data1[i] != write_data1[i] )
112*10465441SEvalZero                 {
113*10465441SEvalZero                     rt_kprintf("fsrw1 data error!\r\n");
114*10465441SEvalZero                     close(fd);
115*10465441SEvalZero                     stop_flag = 1;
116*10465441SEvalZero                     fsrw1_thread = RT_NULL;
117*10465441SEvalZero                     return;
118*10465441SEvalZero                 }
119*10465441SEvalZero             }
120*10465441SEvalZero         }
121*10465441SEvalZero         tick_end = rt_tick_get();
122*10465441SEvalZero         read_speed = fsrw1_data_len*8000UL*RT_TICK_PER_SECOND/(tick_end-tick_start);
123*10465441SEvalZero 
124*10465441SEvalZero         rt_kprintf("thread fsrw1 round %d ",round++);
125*10465441SEvalZero         rt_kprintf("rd:%dbyte/s,wr:%dbyte/s\r\n",read_speed,write_speed);
126*10465441SEvalZero 
127*10465441SEvalZero         /* close file */
128*10465441SEvalZero         close(fd);
129*10465441SEvalZero     }
130*10465441SEvalZero }
131*10465441SEvalZero 
132*10465441SEvalZero #define fsrw2_fn                   "/test2.dat"
133*10465441SEvalZero #define fsrw2_data_len             180              /* Less than 256 */
fsrw2_thread_entry(void * parameter)134*10465441SEvalZero static void fsrw2_thread_entry(void* parameter)
135*10465441SEvalZero {
136*10465441SEvalZero     int fd;
137*10465441SEvalZero     int index,length;
138*10465441SEvalZero     rt_uint32_t round;
139*10465441SEvalZero     rt_uint32_t tick_start,tick_end,read_speed,write_speed;
140*10465441SEvalZero 
141*10465441SEvalZero     static rt_uint8_t write_data2[fsrw2_data_len];
142*10465441SEvalZero     static rt_uint8_t read_data2[fsrw2_data_len];
143*10465441SEvalZero 
144*10465441SEvalZero     round = 1;
145*10465441SEvalZero 
146*10465441SEvalZero     while(1)
147*10465441SEvalZero     {
148*10465441SEvalZero         if( stop_flag )
149*10465441SEvalZero         {
150*10465441SEvalZero             rt_kprintf("thread fsrw1 error,thread fsrw2 quit!\r\n");
151*10465441SEvalZero             fsrw2_thread = RT_NULL;
152*10465441SEvalZero             stop_flag = 0;
153*10465441SEvalZero             return;
154*10465441SEvalZero         }
155*10465441SEvalZero 
156*10465441SEvalZero         /* creat file */
157*10465441SEvalZero         fd = open(fsrw2_fn, O_WRONLY | O_CREAT | O_TRUNC, 0);
158*10465441SEvalZero         if (fd < 0)
159*10465441SEvalZero         {
160*10465441SEvalZero             rt_kprintf("fsrw2 open file for write failed\n");
161*10465441SEvalZero             stop_flag = 1;
162*10465441SEvalZero             fsrw2_thread = RT_NULL;
163*10465441SEvalZero             return;
164*10465441SEvalZero         }
165*10465441SEvalZero 
166*10465441SEvalZero         /* plan write data */
167*10465441SEvalZero         for (index = 0; index < fsrw2_data_len; index ++)
168*10465441SEvalZero         {
169*10465441SEvalZero             write_data2[index] = index;
170*10465441SEvalZero         }
171*10465441SEvalZero 
172*10465441SEvalZero         /* write 5000 times */
173*10465441SEvalZero         tick_start = rt_tick_get();
174*10465441SEvalZero         for(index=0; index<5000; index++)
175*10465441SEvalZero         {
176*10465441SEvalZero             length = write(fd, write_data2, fsrw2_data_len);
177*10465441SEvalZero             if (length != fsrw2_data_len)
178*10465441SEvalZero             {
179*10465441SEvalZero                 rt_kprintf("fsrw2 write data failed\n");
180*10465441SEvalZero                 close(fd);
181*10465441SEvalZero                 stop_flag = 1;
182*10465441SEvalZero                 fsrw2_thread = RT_NULL;
183*10465441SEvalZero                 return;
184*10465441SEvalZero             }
185*10465441SEvalZero         }
186*10465441SEvalZero         tick_end = rt_tick_get();
187*10465441SEvalZero         write_speed = fsrw2_data_len*5000UL*RT_TICK_PER_SECOND/(tick_end-tick_start);
188*10465441SEvalZero 
189*10465441SEvalZero         /* close file */
190*10465441SEvalZero         close(fd);
191*10465441SEvalZero 
192*10465441SEvalZero         /* open file read only */
193*10465441SEvalZero         fd = open(fsrw2_fn, O_RDONLY, 0);
194*10465441SEvalZero         if (fd < 0)
195*10465441SEvalZero         {
196*10465441SEvalZero             rt_kprintf("fsrw2 open file for read failed\n");
197*10465441SEvalZero             stop_flag = 1;
198*10465441SEvalZero             fsrw2_thread = RT_NULL;
199*10465441SEvalZero             return;
200*10465441SEvalZero         }
201*10465441SEvalZero 
202*10465441SEvalZero         /* verify data */
203*10465441SEvalZero         tick_start = rt_tick_get();
204*10465441SEvalZero         for(index=0; index<5000; index++)
205*10465441SEvalZero         {
206*10465441SEvalZero             rt_uint32_t i;
207*10465441SEvalZero 
208*10465441SEvalZero             length = read(fd, read_data2, fsrw2_data_len);
209*10465441SEvalZero             if (length != fsrw2_data_len)
210*10465441SEvalZero             {
211*10465441SEvalZero                 rt_kprintf("fsrw2 read file failed\r\n");
212*10465441SEvalZero                 close(fd);
213*10465441SEvalZero                 stop_flag = 1;
214*10465441SEvalZero                 fsrw2_thread = RT_NULL;
215*10465441SEvalZero                 return;
216*10465441SEvalZero             }
217*10465441SEvalZero             for(i=0; i<fsrw2_data_len; i++)
218*10465441SEvalZero             {
219*10465441SEvalZero                 if( read_data2[i] != write_data2[i] )
220*10465441SEvalZero                 {
221*10465441SEvalZero                     rt_kprintf("fsrw2 data error!\r\n");
222*10465441SEvalZero                     close(fd);
223*10465441SEvalZero                     stop_flag = 1;
224*10465441SEvalZero                     fsrw2_thread = RT_NULL;
225*10465441SEvalZero                     return;
226*10465441SEvalZero                 }
227*10465441SEvalZero             }
228*10465441SEvalZero         }
229*10465441SEvalZero         tick_end = rt_tick_get();
230*10465441SEvalZero         read_speed = fsrw2_data_len*5000UL*RT_TICK_PER_SECOND/(tick_end-tick_start);
231*10465441SEvalZero 
232*10465441SEvalZero         rt_kprintf("thread fsrw2 round %d ",round++);
233*10465441SEvalZero         rt_kprintf("rd:%dbyte/s,wr:%dbyte/s\r\n",read_speed,write_speed);
234*10465441SEvalZero 
235*10465441SEvalZero         /* close file */
236*10465441SEvalZero         close(fd);
237*10465441SEvalZero     }
238*10465441SEvalZero }
239*10465441SEvalZero 
240*10465441SEvalZero 
241*10465441SEvalZero /** \brief startup filesystem read/write test(multi thread).
242*10465441SEvalZero  *
243*10465441SEvalZero  * \param arg rt_uint32_t [0]startup thread1,[1]startup thread2.
244*10465441SEvalZero  * \return void
245*10465441SEvalZero  *
246*10465441SEvalZero  */
fs_test(rt_uint32_t arg)247*10465441SEvalZero void fs_test(rt_uint32_t arg)
248*10465441SEvalZero {
249*10465441SEvalZero     rt_kprintf("arg is : 0x%02X ",arg);
250*10465441SEvalZero 
251*10465441SEvalZero     if(arg & 0x01)
252*10465441SEvalZero     {
253*10465441SEvalZero         if( fsrw1_thread != RT_NULL )
254*10465441SEvalZero         {
255*10465441SEvalZero             rt_kprintf("fsrw1_thread already exists!\r\n");
256*10465441SEvalZero         }
257*10465441SEvalZero         else
258*10465441SEvalZero         {
259*10465441SEvalZero             fsrw1_thread = rt_thread_create( "fsrw1",
260*10465441SEvalZero                                              fsrw1_thread_entry,
261*10465441SEvalZero                                              RT_NULL,
262*10465441SEvalZero                                              2048,
263*10465441SEvalZero                                              RT_THREAD_PRIORITY_MAX-2,
264*10465441SEvalZero                                              1);
265*10465441SEvalZero             if ( fsrw1_thread != RT_NULL)
266*10465441SEvalZero             {
267*10465441SEvalZero                 rt_thread_startup(fsrw1_thread);
268*10465441SEvalZero             }
269*10465441SEvalZero         }
270*10465441SEvalZero     }
271*10465441SEvalZero 
272*10465441SEvalZero     if( arg & 0x02)
273*10465441SEvalZero     {
274*10465441SEvalZero         if( fsrw2_thread != RT_NULL )
275*10465441SEvalZero         {
276*10465441SEvalZero             rt_kprintf("fsrw2_thread already exists!\r\n");
277*10465441SEvalZero         }
278*10465441SEvalZero         else
279*10465441SEvalZero         {
280*10465441SEvalZero             fsrw2_thread = rt_thread_create( "fsrw2",
281*10465441SEvalZero                                              fsrw2_thread_entry,
282*10465441SEvalZero                                              RT_NULL,
283*10465441SEvalZero                                              2048,
284*10465441SEvalZero                                              RT_THREAD_PRIORITY_MAX-2,
285*10465441SEvalZero                                              1);
286*10465441SEvalZero             if ( fsrw2_thread != RT_NULL)
287*10465441SEvalZero             {
288*10465441SEvalZero                 rt_thread_startup(fsrw2_thread);
289*10465441SEvalZero             }
290*10465441SEvalZero         }
291*10465441SEvalZero     }
292*10465441SEvalZero }
293*10465441SEvalZero 
294*10465441SEvalZero #ifdef RT_USING_FINSH
295*10465441SEvalZero #include <finsh.h>
296*10465441SEvalZero FINSH_FUNCTION_EXPORT(fs_test, file system R/W test. e.g: fs_test(3));
297*10465441SEvalZero #endif
298