Make all network interrupt service routines MPSAFE part 1/3.
[dragonfly.git] / sys / net / i4b / driver / i4b_tel.c
1 /*
2  * Copyright (c) 1997, 2001 Hellmuth Michaelis. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
14  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23  * SUCH DAMAGE.
24  *
25  *---------------------------------------------------------------------------
26  *
27  *      i4b_tel.c - device driver for ISDN telephony
28  *      --------------------------------------------
29  *
30  * $FreeBSD: src/sys/i4b/driver/i4b_tel.c,v 1.10.2.4 2001/12/16 15:12:57 hm Exp $
31  * $DragonFly: src/sys/net/i4b/driver/i4b_tel.c,v 1.12 2005/06/15 11:56:03 joerg Exp $
32  *
33  *      last edit-date: [Sat Aug 11 18:07:05 2001]
34  *
35  *---------------------------------------------------------------------------*/
36
37 #include "use_i4btel.h"
38
39 #if NI4BTEL > 0
40
41 #undef I4BTELDEBUG
42
43 #include <sys/param.h>
44 #include <sys/systm.h>
45
46 #include <sys/ioccom.h>
47 #include <sys/poll.h>
48
49 #include <sys/conf.h>
50 #include <sys/uio.h>
51 #include <sys/kernel.h>
52 #include <sys/mbuf.h>
53 #include <sys/socket.h>
54 #include <net/if.h>
55 #include <sys/thread2.h>
56 #include <sys/tty.h>
57
58 #ifdef DEVFS
59 #include <sys/devfsext.h>
60 #endif
61
62 #include <net/i4b/include/machine/i4b_ioctl.h>
63 #include <net/i4b/include/machine/i4b_tel_ioctl.h>
64 #include <net/i4b/include/machine/i4b_debug.h>
65
66 #include "../include/i4b_global.h"
67 #include "../include/i4b_mbuf.h"
68 #include "../include/i4b_l3l4.h"
69 #include "../layer4/i4b_l4.h"
70
71 /* minor number: lower 6 bits = unit number */
72
73 #define UNITBITS        6
74 #define UNITMASK        0x3f
75 #define UNIT(n)         (minor(n) & UNITMASK)
76
77 /* minor number: upper 2 bits = function number */
78
79 #define FUNCMASK        0x03
80 #define FUNC(n)         (((minor(n)) >> UNITBITS) & FUNCMASK)
81
82 #define FUNCTEL         0       /* 0 = normal i4btel device     */
83 #define FUNCDIAL        1       /* 1 = i4bteld dialout device   */
84
85 #define NOFUNCS         2       /* number of device classes     */
86
87 typedef struct {
88
89         /* used only in func = FUNCTEL */
90
91         drvr_link_t             drvr_linktab;   /* driver linktab */
92         isdn_link_t             *isdn_linktab;  /* isdn linktab */
93         int                     audiofmt;       /* audio format conversion */
94         u_char                  *rcvttab;       /* conversion table on read */
95         u_char                  *wcvttab;       /* conversion table on write */
96         call_desc_t             *cdp;           /* call descriptor pointer */
97
98         /* used only in func = FUNCDIAL */
99
100         char                    result;         /* result code for dial dev */  
101
102         /* used in func = FUNCDIAL and func = FUNCTEL*/
103         
104         int                     devstate;       /* state of this unit   */
105 #define ST_IDLE         0x00            /* idle */
106 #define ST_CONNECTED    0x01            /* isdn connected state */
107 #define ST_ISOPEN       0x02            /* userland opened */
108 #define ST_RDWAITDATA   0x04            /* userland read waiting */
109 #define ST_WRWAITEMPTY  0x08            /* userland write waiting */
110 #define ST_TONE         0x10            /* tone generator */
111
112         struct selinfo          selp;           /* select / poll */
113
114         struct i4b_tel_tones    tones;
115         int                     toneidx;
116         int                     toneomega;
117         int                     tonefreq;
118
119 } tel_sc_t;
120
121 static tel_sc_t tel_sc[NI4BTEL][NOFUNCS];
122         
123 /* forward decl */
124
125 static void tel_rx_data_rdy(int unit);
126 static void tel_tx_queue_empty(int unit);
127 static void tel_init_linktab(int unit);
128 static void tel_connect(int unit, void *cdp);
129 static void tel_disconnect(int unit, void *cdp);
130 static void tel_tone(tel_sc_t *sc);
131
132 /* audio format conversion tables */
133 static unsigned char a2u_tab[];
134 static unsigned char u2a_tab[];
135 static unsigned char bitreverse[];
136 static u_char sinetab[];
137
138 #define PDEVSTATIC      static
139
140 PDEVSTATIC d_open_t     i4btelopen;
141 PDEVSTATIC d_close_t    i4btelclose;
142 PDEVSTATIC d_read_t     i4btelread;
143 PDEVSTATIC d_read_t     i4btelwrite;
144 PDEVSTATIC d_ioctl_t    i4btelioctl;
145
146 PDEVSTATIC d_poll_t i4btelpoll;
147 #define POLLFIELD i4btelpoll
148
149 #define CDEV_MAJOR 56
150
151 static struct cdevsw i4btel_cdevsw = {
152         /* name */      "i4btel",
153         /* maj */       CDEV_MAJOR,
154         /* flags */     0,
155         /* port */      NULL,
156         /* clone */     NULL,
157
158         /* open */      i4btelopen,
159         /* close */     i4btelclose,
160         /* read */      i4btelread,
161         /* write */     i4btelwrite,
162         /* ioctl */     i4btelioctl,
163         /* poll */      POLLFIELD,
164         /* mmap */      nommap,
165         /* strategy */  nostrategy,
166         /* dump */      nodump,
167         /* psize */     nopsize
168 };
169
170 PDEVSTATIC void i4btelinit(void *unused);
171 PDEVSTATIC void i4btelattach(void *);
172
173 PSEUDO_SET(i4btelattach, i4b_tel);
174
175 /*===========================================================================*
176  *                      DEVICE DRIVER ROUTINES
177  *===========================================================================*/
178
179 /*---------------------------------------------------------------------------*
180  *      initialization at kernel load time
181  *---------------------------------------------------------------------------*/
182 PDEVSTATIC void
183 i4btelinit(void *unused)
184 {
185         cdevsw_add(&i4btel_cdevsw, 0, 0);
186 }
187
188 SYSINIT(i4bteldev, SI_SUB_DRIVERS,
189         SI_ORDER_MIDDLE+CDEV_MAJOR, &i4btelinit, NULL);
190
191 /*---------------------------------------------------------------------------*
192  *      interface attach routine
193  *---------------------------------------------------------------------------*/
194 PDEVSTATIC void
195 i4btelattach(void *dummy)
196 {
197         int i, j;
198
199         printf("i4btel: %d ISDN telephony interface device(s) attached\n", NI4BTEL);
200         
201         for(i=0; i < NI4BTEL; i++)
202         {
203                 for(j=0; j < NOFUNCS; j++)
204                 {
205                         tel_sc[i][j].devstate = ST_IDLE;
206                         tel_sc[i][j].audiofmt = CVT_NONE;
207                         tel_sc[i][j].rcvttab = 0;
208                         tel_sc[i][j].wcvttab = 0;
209                         tel_sc[i][j].result = 0;
210
211                         switch(j)
212                         {
213                                 case FUNCTEL:   /* normal i4btel device */
214                                         make_dev(&i4btel_cdevsw, i,
215                                                 UID_ROOT, GID_WHEEL,
216                                                 0600, "i4btel%d", i);
217                                         break;
218                                 
219                                 case FUNCDIAL:  /* i4bteld dialout device */
220                                         make_dev(&i4btel_cdevsw, i+(1<<UNITBITS),
221                                                 UID_ROOT, GID_WHEEL,
222                                                 0600, "i4bteld%d", i);
223                                         break;
224                         }
225                 }
226                 tel_init_linktab(i);            
227         }
228 }
229
230 /*---------------------------------------------------------------------------*
231  *      open tel device
232  *---------------------------------------------------------------------------*/
233 PDEVSTATIC int
234 i4btelopen(dev_t dev, int flag, int fmt, struct thread *td)
235 {
236         int unit = UNIT(dev);
237         int func = FUNC(dev);
238         
239         tel_sc_t *sc;
240         
241         if(unit >= NI4BTEL)
242                 return(ENXIO);
243
244         sc = &tel_sc[unit][func];               
245
246         if(sc->devstate & ST_ISOPEN)
247                 return(EBUSY);
248
249         sc->devstate |= ST_ISOPEN;              
250
251         if(func == FUNCDIAL)
252         {
253                 sc->result = 0;
254         }
255         
256         return(0);
257 }
258
259 /*---------------------------------------------------------------------------*
260  *      close tel device
261  *---------------------------------------------------------------------------*/
262 PDEVSTATIC int
263 i4btelclose(dev_t dev, int flag, int fmt, struct thread *td)
264 {
265         int unit = UNIT(dev);
266         int func = FUNC(dev);
267         tel_sc_t *sc;
268         int error = 0;
269         
270         if(unit > NI4BTEL)
271                 return(ENXIO);
272
273         sc = &tel_sc[unit][func];               
274
275         crit_enter();
276         sc->devstate &= ~ST_TONE;               
277
278         if((func == FUNCTEL) &&
279            (sc->isdn_linktab != NULL && sc->isdn_linktab->tx_queue != NULL))
280         {
281                 while(!(IF_QEMPTY(sc->isdn_linktab->tx_queue)))
282                 {
283                         sc->devstate |= ST_WRWAITEMPTY;
284         
285                         if((error = tsleep((caddr_t) &sc->isdn_linktab->tx_queue,
286                                         PCATCH, "wtcl", 0)) != 0)
287                         {
288                                 break;
289                         }
290                 }
291                 sc->devstate &= ~ST_WRWAITEMPTY;                
292         }
293
294         sc->devstate &= ~ST_ISOPEN;             
295         crit_exit();
296         wakeup((caddr_t) &sc->tones);
297
298         return(error);
299 }
300
301 /*---------------------------------------------------------------------------*
302  *      i4btelioctl - device driver ioctl routine
303  *---------------------------------------------------------------------------*/
304 PDEVSTATIC int
305 i4btelioctl(dev_t dev, u_long cmd, caddr_t data, int flag, struct thread *td)
306 {
307         int unit = UNIT(dev);
308         int func = FUNC(dev);
309         int error = 0;
310         struct mbuf *m;
311
312         tel_sc_t *sc = &tel_sc[unit][func];
313
314         if(func == FUNCTEL)
315         {
316                 switch(cmd)
317                 {
318                         case I4B_TEL_GETAUDIOFMT:
319                                 *(int *)data = sc->audiofmt;
320                                 break;
321                         
322                         case I4B_TEL_SETAUDIOFMT:
323                                 switch (*(int *)data)
324                                 {
325                                         case CVT_NONE:
326                                                 sc->rcvttab = 0;
327                                                 sc->wcvttab = 0;
328                                                 break;
329                                         case CVT_ALAW2ULAW:
330                                                 /* ISDN: a-law */
331                                                 /* user: u-law */ 
332                                                 sc->rcvttab = a2u_tab;
333                                                 sc->wcvttab = u2a_tab;
334                                                 break;
335                                         case CVT_ULAW2ALAW:
336                                                 /* ISDN: u-law */
337                                                 /* user: a-law */ 
338                                                 sc->rcvttab = u2a_tab;
339                                                 sc->wcvttab = a2u_tab;
340                                                 break;
341                                         default:
342                                                 error = ENODEV;
343                                                 break;
344                                 }
345                                 if(error == 0)
346                                         sc->audiofmt = *(int *)data;
347                                 break;
348         
349                         case I4B_TEL_EMPTYINPUTQUEUE:
350                                 crit_enter();
351                                 while((sc->devstate & ST_CONNECTED)     &&
352                                         (sc->devstate & ST_ISOPEN)      &&
353                                         !IF_QEMPTY(sc->isdn_linktab->rx_queue))
354                                 {
355                                         IF_DEQUEUE(sc->isdn_linktab->rx_queue, m);
356                                         if(m)
357                                                 i4b_Bfreembuf(m);
358                                 }
359                                 crit_exit();
360                                 break;
361
362                         case I4B_TEL_VR_REQ:
363                         {
364                                 msg_vr_req_t *mvr;
365
366                                 mvr = (msg_vr_req_t *)data;
367
368                                 mvr->version = VERSION;
369                                 mvr->release = REL;
370                                 mvr->step = STEP;                       
371                                 break;
372                         }
373                         case I4B_TEL_TONES:
374                         {
375                                 struct i4b_tel_tones *tt;
376
377                                 tt = (struct i4b_tel_tones *)data;
378                                 crit_enter();
379                                 while ((sc->devstate & ST_TONE) && 
380                                     sc->tones.duration[sc->toneidx] != 0) {
381                                         if((error = tsleep((caddr_t) &sc->tones,
382                                             PCATCH, "rtone", 0 )) != 0) {
383                                                 crit_exit();
384                                                 return(error);
385                                         }
386                                 } 
387                                 if(!(sc->devstate & ST_ISOPEN)) {
388                                         crit_exit();
389                                         return (EIO);
390                                 }
391                                 if(!(sc->devstate & ST_CONNECTED)) {
392                                         crit_exit();
393                                         return (EIO);
394                                 }
395
396                                 sc->tones = *tt;
397                                 sc->toneidx = 0;
398                                 sc->tonefreq = tt->frequency[0];
399                                 sc->devstate |= ST_TONE;
400                                 crit_exit();
401                                 tel_tone(sc);
402                                 break;
403                         }
404         
405                         default:
406                                 error = ENOTTY;
407                                 break;
408                 }
409         }
410         else if(func == FUNCDIAL)
411         {
412                 switch(cmd)
413                 {
414                         default:
415                                 error = ENOTTY;
416                                 break;
417                 }
418         }               
419         return(error);
420 }
421
422 /*---------------------------------------------------------------------------*
423  *      read from tel device
424  *---------------------------------------------------------------------------*/
425 PDEVSTATIC int
426 i4btelread(dev_t dev, struct uio *uio, int ioflag)
427 {
428         int unit = UNIT(dev);
429         int func = FUNC(dev);
430
431         struct mbuf *m;
432         int error = 0;
433
434         tel_sc_t *sc = &tel_sc[unit][func];
435         
436         if(!(sc->devstate & ST_ISOPEN))
437                 return(EIO);
438
439         if(func == FUNCTEL)
440         {
441                 crit_enter();
442
443                 while((sc->devstate & ST_ISOPEN)        &&
444                       (sc->devstate & ST_CONNECTED)     &&
445                       IF_QEMPTY(sc->isdn_linktab->rx_queue))            
446                 {
447                         sc->devstate |= ST_RDWAITDATA;
448
449                         NDBGL4(L4_TELDBG, "i4btel%d, queue empty!", unit);
450
451                         if((error = tsleep((caddr_t) &sc->isdn_linktab->rx_queue,
452                                                 PCATCH, "rtel", 0 )) != 0)
453                         {
454                                 sc->devstate &= ~ST_RDWAITDATA;
455                                 crit_exit();
456                                 return(error);
457                         }
458                 }
459         
460                 if(!(sc->devstate & ST_ISOPEN))
461                 {
462                         crit_exit();
463                         return(EIO);
464                 }
465         
466                 if(!(sc->devstate & ST_CONNECTED))
467                 {
468                         crit_exit();
469                         return(EIO);
470                 }
471                 
472         
473                 IF_DEQUEUE(sc->isdn_linktab->rx_queue, m);
474                 
475                 if(m && m->m_len > 0)
476                 {
477                         int i;
478
479                         for(i = 0; i < m->m_len; i++)
480                         {
481                                 /* always reverse bit order from line */
482                                 mtod(m,u_char *)[i] = bitreverse[mtod(m,u_char *)[i]];
483
484                                 /* convert if necessary */
485                                 if(sc->rcvttab)
486                                         mtod(m,u_char *)[i] = sc->rcvttab[mtod(m,u_char *)[i]];
487                         }
488                         error = uiomove(m->m_data, m->m_len, uio);
489
490                         NDBGL4(L4_TELDBG, "i4btel%d, mbuf (%d bytes), uiomove %d!", unit, m->m_len, error);
491                 }
492                 else
493                 {
494                         NDBGL4(L4_TELDBG, "i4btel%d, empty mbuf from queue!", unit);
495                         error = EIO;
496                 }
497                         
498                 if(m)
499                         i4b_Bfreembuf(m);
500         
501                 crit_exit();
502         }
503         else if(func == FUNCDIAL)
504         {
505                 crit_enter();
506                 while((sc->result == 0) && (sc->devstate & ST_ISOPEN))
507                 {
508                         sc->devstate |= ST_RDWAITDATA;
509         
510                         if((error = tsleep((caddr_t) &sc->result,
511                                                 PCATCH, "rtel1", 0 )) != 0)
512                         {
513                                 sc->devstate &= ~ST_RDWAITDATA;
514                                 crit_exit();
515                                 return(error);
516                         }
517                 }
518         
519                 if(!(sc->devstate & ST_ISOPEN))
520                 {
521                         crit_exit();
522                         return(EIO);
523                 }
524         
525                 if(sc->result != 0)
526                 {
527                         error = uiomove(&sc->result, 1, uio);
528                         sc->result = 0;
529                 }
530                 else
531                 {
532                         error = EIO;
533                 }
534
535                 crit_exit();
536         }
537         return(error);
538 }
539
540 /*---------------------------------------------------------------------------*
541  *      write to tel device
542  *---------------------------------------------------------------------------*/
543 PDEVSTATIC int
544 i4btelwrite(dev_t dev, struct uio * uio, int ioflag)
545 {
546         int unit = UNIT(dev);
547         int func = FUNC(dev);
548         struct mbuf *m;
549         int error = 0;
550         tel_sc_t *sc = &tel_sc[unit][func];
551         
552         if(!(sc->devstate & ST_ISOPEN))
553         {
554                 return(EIO);
555         }
556
557         if(func == FUNCTEL)
558         {
559                 crit_enter();
560                 
561                 if(!(sc->devstate & ST_CONNECTED)) {
562                         crit_exit();
563                         return(EIO);
564                 }
565                         
566                 sc->devstate &= ~ST_TONE;               
567                 while((IF_QFULL(sc->isdn_linktab->tx_queue)) &&
568                       (sc->devstate & ST_ISOPEN))
569                 {
570                         sc->devstate |= ST_WRWAITEMPTY;
571
572                         if((error = tsleep((caddr_t) &sc->isdn_linktab->tx_queue,
573                                         PCATCH, "wtel", 0)) != 0)
574                         {
575                                 sc->devstate &= ~ST_WRWAITEMPTY;
576                                 crit_exit();
577                                 return(error);
578                         }
579                 }
580         
581                 if(!(sc->devstate & ST_ISOPEN))
582                 {
583                         crit_exit();
584                         return(EIO);
585                 }
586         
587                 if(!(sc->devstate & ST_CONNECTED))
588                 {
589                         crit_exit();
590                         return(EIO);
591                 }
592
593                 if((m = i4b_Bgetmbuf(BCH_MAX_DATALEN)) != NULL)
594                 {
595                         int i;
596                         
597                         m->m_len = min(BCH_MAX_DATALEN, uio->uio_resid);
598         
599                         error = uiomove(m->m_data, m->m_len, uio);
600         
601                         for(i = 0; i < m->m_len; i++)
602                         {
603                                 /* convert if necessary */
604                                 if(sc->wcvttab)
605                                         mtod(m,u_char *)[i] = sc->wcvttab[mtod(m,u_char *)[i]];
606
607                                 /* always reverse bitorder to line */
608                                 mtod(m,u_char *)[i] = bitreverse[mtod(m,u_char *)[i]];
609                         }
610
611                         if(IF_QFULL(sc->isdn_linktab->tx_queue))
612                                 m_freem(m);
613                         else
614                                 IF_ENQUEUE(sc->isdn_linktab->tx_queue, m);
615                         (*sc->isdn_linktab->bch_tx_start)(sc->isdn_linktab->unit, sc->isdn_linktab->channel);
616                 }
617         
618                 crit_exit();
619         }
620         else if(func == FUNCDIAL)
621         {
622 #define CMDBUFSIZ 80 
623                 char cmdbuf[CMDBUFSIZ];
624                 int len = min(CMDBUFSIZ-1, uio->uio_resid);
625         
626                 error = uiomove(cmdbuf, len, uio);
627
628                 if(cmdbuf[0] == CMD_DIAL)
629                 {
630                         i4b_l4_dialoutnumber(BDRV_TEL, unit, len-1, &cmdbuf[1]);
631                 }
632                 else if(cmdbuf[0] == CMD_HUP)
633                 {
634                         i4b_l4_drvrdisc(BDRV_TEL, unit);
635                 }
636                 else if(cmdbuf[0] == CMD_KEYP)
637                 {
638                         i4b_l4_keypad(BDRV_TEL, unit, len-1, &cmdbuf[1]);
639                 }
640         }
641         else
642         {
643                 error = EIO;
644         }               
645         
646         return(error);
647 }
648
649 /*---------------------------------------------------------------------------*
650  *      
651  *---------------------------------------------------------------------------*/
652 #define NTONESAMP 32
653 static void
654 tel_tone(tel_sc_t *sc)
655 {
656         struct mbuf *m;
657         u_char *p;
658         int i;
659
660         if((m = i4b_Bgetmbuf(NTONESAMP)) == NULL) {
661                 printf("no mbuf in tel_tone\n");
662                 return;
663         }
664         p = m->m_data;
665         m->m_len = 0;
666         for (i = 0; i < NTONESAMP && (sc->devstate & ST_TONE); i++) {
667
668                 if (sc->tones.duration[sc->toneidx] > 0) {
669                         if (--sc->tones.duration[sc->toneidx] == 0) {
670                                 sc->toneidx++;
671                                 if (sc->toneidx == I4B_TEL_MAXTONES) {
672                                         sc->devstate &= ~ST_TONE;
673                                         sc->toneomega = 0;
674                                         sc->tonefreq = 0;
675                                 } else if (sc->tones.frequency[sc->toneidx] == 0 &&
676                                            sc->tones.duration[sc->toneidx] == 0) {
677                                         sc->devstate &= ~ST_TONE;
678                                         sc->toneomega = 0;
679                                         sc->tonefreq = 0;
680                                 } else {
681                                         sc->tonefreq = sc->tones.frequency[sc->toneidx];
682                                 }
683                                 if (sc->tones.duration[sc->toneidx] == 0) {
684                                         wakeup((caddr_t) &sc->tones);
685                                 }
686                         }
687                 }
688
689                 sc->toneomega += sc->tonefreq;
690                 if (sc->toneomega >= 8000)
691                         sc->toneomega -= 8000;
692                 *p++ = bitreverse[sinetab[sc->toneomega]];
693                 m->m_len++;
694         }
695         IF_ENQUEUE(sc->isdn_linktab->tx_queue, m);
696         (*sc->isdn_linktab->bch_tx_start)(sc->isdn_linktab->unit, sc->isdn_linktab->channel);
697 }
698
699 /*---------------------------------------------------------------------------*
700  *      device driver poll
701  *---------------------------------------------------------------------------*/
702 PDEVSTATIC int
703 i4btelpoll(dev_t dev, int events, struct thread *td)
704 {
705         int revents = 0;        /* Events we found */
706         int unit = UNIT(dev);
707         int func = FUNC(dev);   
708
709         tel_sc_t *sc = &tel_sc[unit][func];
710         
711         crit_enter();
712
713         if(!(sc->devstate & ST_ISOPEN))
714         {
715                 NDBGL4(L4_TELDBG, "i4btel%d, !ST_ISOPEN", unit);
716                 crit_exit();
717                 return(0);
718         }
719
720         if(func == FUNCTEL)
721         {
722                 /*
723                  * Writes are OK if we are connected and the
724                  * transmit queue can take them
725                  */
726                  
727                 if((events & (POLLOUT|POLLWRNORM))      &&
728                         (sc->devstate & ST_CONNECTED)   &&
729                         (sc->isdn_linktab != NULL)      &&
730                         (!IF_QFULL(sc->isdn_linktab->tx_queue)))
731                 {
732                         NDBGL4(L4_TELDBG, "i4btel%d, POLLOUT", unit);
733                         revents |= (events & (POLLOUT|POLLWRNORM));
734                 }
735                 
736                 /* ... while reads are OK if we have any data */
737         
738                 if((events & (POLLIN|POLLRDNORM))       &&
739                         (sc->devstate & ST_CONNECTED)   &&
740                         (sc->isdn_linktab != NULL)      &&
741                         (!IF_QEMPTY(sc->isdn_linktab->rx_queue)))
742                 {
743                         NDBGL4(L4_TELDBG, "i4btel%d, POLLIN", unit);
744                         revents |= (events & (POLLIN|POLLRDNORM));
745                 }
746                         
747                 if(revents == 0)
748                 {
749                         NDBGL4(L4_TELDBG, "i4btel%d, selrecord", unit);
750                         selrecord(td, &sc->selp);
751                 }
752         }
753         else if(func == FUNCDIAL)
754         {
755                 if(events & (POLLOUT|POLLWRNORM))
756                 {
757                         NDBGL4(L4_TELDBG, "i4bteld%d,  POLLOUT", unit);
758                         revents |= (events & (POLLOUT|POLLWRNORM));
759                 }
760
761                 if(events & (POLLIN|POLLRDNORM))
762                 {
763                         NDBGL4(L4_TELDBG, "i4bteld%d,  POLLIN, result = %d", unit, sc->result);
764                         if(sc->result != 0)
765                                 revents |= (events & (POLLIN|POLLRDNORM));
766                 }
767                         
768                 if(revents == 0)
769                 {
770                         NDBGL4(L4_TELDBG, "i4bteld%d,  selrecord", unit);
771                         selrecord(td, &sc->selp);
772                 }
773         }
774         crit_exit();
775         return(revents);
776 }
777
778 /*===========================================================================*
779  *                      ISDN INTERFACE ROUTINES
780  *===========================================================================*/
781
782 /*---------------------------------------------------------------------------*
783 *       this routine is called from L4 handler at connect time
784  *---------------------------------------------------------------------------*/
785 static void
786 tel_connect(int unit, void *cdp)
787 {
788         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
789
790         /* audio device */
791         
792         sc->cdp = (call_desc_t *)cdp;
793
794         sc->devstate |= ST_CONNECTED;
795
796         /* dialer device */
797         
798         sc = &tel_sc[unit][FUNCDIAL];
799
800         if(sc->devstate == ST_ISOPEN)
801         {
802                 sc->result = RSP_CONN;
803
804                 if(sc->devstate & ST_RDWAITDATA)
805                 {
806                         sc->devstate &= ~ST_RDWAITDATA;
807                         wakeup((caddr_t) &sc->result);
808                 }
809                 selwakeup(&sc->selp);
810         }
811 }
812
813 /*---------------------------------------------------------------------------*
814  *      this routine is called from L4 handler at disconnect time
815  *---------------------------------------------------------------------------*/
816 static void
817 tel_disconnect(int unit, void *cdp)
818 {
819 /*      call_desc_t *cd = (call_desc_t *)cdp; */
820
821         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
822         
823         /* audio device */
824         
825         sc->devstate &= ~ST_CONNECTED;
826
827         if(sc->devstate & ST_RDWAITDATA)
828         {
829                 sc->devstate &= ~ST_RDWAITDATA;
830                 wakeup((caddr_t) &sc->isdn_linktab->rx_queue);
831         }
832
833         if(sc->devstate & ST_WRWAITEMPTY)
834         {
835                 sc->devstate &= ~ST_WRWAITEMPTY;
836                 wakeup((caddr_t) &sc->isdn_linktab->tx_queue);
837         }
838
839         /* dialer device */
840         
841         sc = &tel_sc[unit][FUNCDIAL];
842
843         if(sc->devstate & ST_ISOPEN)
844         {
845                 sc->result = RSP_HUP;
846
847                 if(sc->devstate & ST_RDWAITDATA)
848                 {
849                         sc->devstate &= ~ST_RDWAITDATA;
850                         wakeup((caddr_t) &sc->result);
851                 }
852                 selwakeup(&sc->selp);
853
854                 if (sc->devstate & ST_TONE) {
855                         sc->devstate &= ~ST_TONE;
856                         wakeup((caddr_t) &sc->tones);
857                 }
858         }
859 }
860
861 /*---------------------------------------------------------------------------*
862  *      feedback from daemon in case of dial problems
863  *---------------------------------------------------------------------------*/
864 static void
865 tel_dialresponse(int unit, int status, cause_t cause)
866 {       
867         tel_sc_t *sc = &tel_sc[unit][FUNCDIAL];
868
869         NDBGL4(L4_TELDBG, "i4btel%d,  status=%d, cause=0x%4x", unit, status, cause);
870
871         if((sc->devstate == ST_ISOPEN) && status)
872         {       
873                 sc->result = RSP_NOA;
874
875                 if(sc->devstate & ST_RDWAITDATA)
876                 {
877                         sc->devstate &= ~ST_RDWAITDATA;
878                         wakeup((caddr_t) &sc->result);
879                 }
880                 selwakeup(&sc->selp);
881         }
882 }
883         
884 /*---------------------------------------------------------------------------*
885  *      interface up/down
886  *---------------------------------------------------------------------------*/
887 static void
888 tel_updown(int unit, int updown)
889 {
890 }
891         
892 /*---------------------------------------------------------------------------*
893  *      this routine is called from the HSCX interrupt handler
894  *      when a new frame (mbuf) has been received and was put on
895  *      the rx queue.
896  *---------------------------------------------------------------------------*/
897 static void
898 tel_rx_data_rdy(int unit)
899 {
900         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
901         
902         if(sc->devstate & ST_RDWAITDATA)
903         {
904                 sc->devstate &= ~ST_RDWAITDATA;
905                 wakeup((caddr_t) &sc->isdn_linktab->rx_queue);
906         }
907         selwakeup(&sc->selp);
908 }
909
910 /*---------------------------------------------------------------------------*
911  *      this routine is called from the HSCX interrupt handler
912  *      when the last frame has been sent out and there is no
913  *      further frame (mbuf) in the tx queue.
914  *---------------------------------------------------------------------------*/
915 static void
916 tel_tx_queue_empty(int unit)
917 {
918         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
919
920         if(sc->devstate & ST_WRWAITEMPTY)
921         {
922                 sc->devstate &= ~ST_WRWAITEMPTY;
923                 wakeup((caddr_t) &sc->isdn_linktab->tx_queue);
924         }
925         if(sc->devstate & ST_TONE) {
926                 tel_tone(sc);
927         } else {
928                 selwakeup(&sc->selp);
929         }
930 }
931
932 /*---------------------------------------------------------------------------*
933  *      this routine is called from the HSCX interrupt handler
934  *      each time a packet is received or transmitted.
935  *---------------------------------------------------------------------------*/
936 static void
937 tel_activity(int unit, int rxtx)
938 {
939         if(tel_sc[unit][FUNCTEL].cdp)
940                 tel_sc[unit][FUNCTEL].cdp->last_active_time = SECOND;
941 }
942
943 /*---------------------------------------------------------------------------*
944  *      return this drivers linktab address
945  *---------------------------------------------------------------------------*/
946 drvr_link_t *
947 tel_ret_linktab(int unit)
948 {
949         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
950         
951         tel_init_linktab(unit);
952         return(&sc->drvr_linktab);
953 }
954
955 /*---------------------------------------------------------------------------*
956  *      setup the isdn_linktab for this driver
957  *---------------------------------------------------------------------------*/
958 void
959 tel_set_linktab(int unit, isdn_link_t *ilt)
960 {
961         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
962         sc->isdn_linktab = ilt;
963 }
964
965 /*---------------------------------------------------------------------------*
966  *      initialize this drivers linktab
967  *---------------------------------------------------------------------------*/
968 static void
969 tel_init_linktab(int unit)
970 {
971         tel_sc_t *sc = &tel_sc[unit][FUNCTEL];
972         
973         sc->drvr_linktab.unit = unit;
974         sc->drvr_linktab.bch_rx_data_ready = tel_rx_data_rdy;
975         sc->drvr_linktab.bch_tx_queue_empty = tel_tx_queue_empty;
976         sc->drvr_linktab.bch_activity = tel_activity;   
977         sc->drvr_linktab.line_connected = tel_connect;
978         sc->drvr_linktab.line_disconnected = tel_disconnect;
979         sc->drvr_linktab.dial_response = tel_dialresponse;
980         sc->drvr_linktab.updown_ind = tel_updown;       
981 }
982
983 /*===========================================================================*
984  *      AUDIO FORMAT CONVERSION (produced by running g711conv)
985  *===========================================================================*/
986
987 /*---------------------------------------------------------------------------*
988  *      A-law to u-law conversion
989  *---------------------------------------------------------------------------*/
990 static unsigned char a2u_tab[256] = {
991 /* 00 */        0x2a, 0x2b, 0x28, 0x29, 0x2e, 0x2f, 0x2c, 0x2d, 
992 /* 08 */        0x22, 0x23, 0x20, 0x21, 0x26, 0x27, 0x24, 0x25, 
993 /* 10 */        0x39, 0x3a, 0x37, 0x38, 0x3d, 0x3e, 0x3b, 0x3c, 
994 /* 18 */        0x31, 0x32, 0x30, 0x30, 0x35, 0x36, 0x33, 0x34, 
995 /* 20 */        0x0a, 0x0b, 0x08, 0x09, 0x0e, 0x0f, 0x0c, 0x0d, 
996 /* 28 */        0x02, 0x03, 0x00, 0x01, 0x06, 0x07, 0x04, 0x05, 
997 /* 30 */        0x1a, 0x1b, 0x18, 0x19, 0x1e, 0x1f, 0x1c, 0x1d, 
998 /* 38 */        0x12, 0x13, 0x10, 0x11, 0x16, 0x17, 0x14, 0x15, 
999 /* 40 */        0x62, 0x63, 0x60, 0x61, 0x66, 0x67, 0x64, 0x65, 
1000 /* 48 */        0x5d, 0x5d, 0x5c, 0x5c, 0x5f, 0x5f, 0x5e, 0x5e, 
1001 /* 50 */        0x74, 0x76, 0x70, 0x72, 0x7c, 0x7e, 0x78, 0x7a, 
1002 /* 58 */        0x6a, 0x6b, 0x68, 0x69, 0x6e, 0x6f, 0x6c, 0x6d, 
1003 /* 60 */        0x48, 0x49, 0x46, 0x47, 0x4c, 0x4d, 0x4a, 0x4b, 
1004 /* 68 */        0x40, 0x41, 0x3f, 0x3f, 0x44, 0x45, 0x42, 0x43, 
1005 /* 70 */        0x56, 0x57, 0x54, 0x55, 0x5a, 0x5b, 0x58, 0x59, 
1006 /* 78 */        0x4f, 0x4f, 0x4e, 0x4e, 0x52, 0x53, 0x50, 0x51, 
1007 /* 80 */        0xaa, 0xab, 0xa8, 0xa9, 0xae, 0xaf, 0xac, 0xad, 
1008 /* 88 */        0xa2, 0xa3, 0xa0, 0xa1, 0xa6, 0xa7, 0xa4, 0xa5, 
1009 /* 90 */        0xb9, 0xba, 0xb7, 0xb8, 0xbd, 0xbe, 0xbb, 0xbc, 
1010 /* 98 */        0xb1, 0xb2, 0xb0, 0xb0, 0xb5, 0xb6, 0xb3, 0xb4, 
1011 /* a0 */        0x8a, 0x8b, 0x88, 0x89, 0x8e, 0x8f, 0x8c, 0x8d, 
1012 /* a8 */        0x82, 0x83, 0x80, 0x81, 0x86, 0x87, 0x84, 0x85, 
1013 /* b0 */        0x9a, 0x9b, 0x98, 0x99, 0x9e, 0x9f, 0x9c, 0x9d, 
1014 /* b8 */        0x92, 0x93, 0x90, 0x91, 0x96, 0x97, 0x94, 0x95, 
1015 /* c0 */        0xe2, 0xe3, 0xe0, 0xe1, 0xe6, 0xe7, 0xe4, 0xe5, 
1016 /* c8 */        0xdd, 0xdd, 0xdc, 0xdc, 0xdf, 0xdf, 0xde, 0xde, 
1017 /* d0 */        0xf4, 0xf6, 0xf0, 0xf2, 0xfc, 0xfe, 0xf8, 0xfa, 
1018 /* d8 */        0xea, 0xeb, 0xe8, 0xe9, 0xee, 0xef, 0xec, 0xed, 
1019 /* e0 */        0xc8, 0xc9, 0xc6, 0xc7, 0xcc, 0xcd, 0xca, 0xcb, 
1020 /* e8 */        0xc0, 0xc1, 0xbf, 0xbf, 0xc4, 0xc5, 0xc2, 0xc3, 
1021 /* f0 */        0xd6, 0xd7, 0xd4, 0xd5, 0xda, 0xdb, 0xd8, 0xd9, 
1022 /* f8 */        0xcf, 0xcf, 0xce, 0xce, 0xd2, 0xd3, 0xd0, 0xd1
1023 };
1024
1025 /*---------------------------------------------------------------------------*
1026  *      u-law to A-law conversion
1027  *---------------------------------------------------------------------------*/
1028 static unsigned char u2a_tab[256] = {
1029 /* 00 */        0x2a, 0x2b, 0x28, 0x29, 0x2e, 0x2f, 0x2c, 0x2d, 
1030 /* 08 */        0x22, 0x23, 0x20, 0x21, 0x26, 0x27, 0x24, 0x25, 
1031 /* 10 */        0x3a, 0x3b, 0x38, 0x39, 0x3e, 0x3f, 0x3c, 0x3d, 
1032 /* 18 */        0x32, 0x33, 0x30, 0x31, 0x36, 0x37, 0x34, 0x35, 
1033 /* 20 */        0x0a, 0x0b, 0x08, 0x09, 0x0e, 0x0f, 0x0c, 0x0d, 
1034 /* 28 */        0x02, 0x03, 0x00, 0x01, 0x06, 0x07, 0x04, 0x05, 
1035 /* 30 */        0x1b, 0x18, 0x19, 0x1e, 0x1f, 0x1c, 0x1d, 0x12, 
1036 /* 38 */        0x13, 0x10, 0x11, 0x16, 0x17, 0x14, 0x15, 0x6a, 
1037 /* 40 */        0x68, 0x69, 0x6e, 0x6f, 0x6c, 0x6d, 0x62, 0x63, 
1038 /* 48 */        0x60, 0x61, 0x66, 0x67, 0x64, 0x65, 0x7a, 0x78, 
1039 /* 50 */        0x7e, 0x7f, 0x7c, 0x7d, 0x72, 0x73, 0x70, 0x71, 
1040 /* 58 */        0x76, 0x77, 0x74, 0x75, 0x4b, 0x49, 0x4f, 0x4d, 
1041 /* 60 */        0x42, 0x43, 0x40, 0x41, 0x46, 0x47, 0x44, 0x45, 
1042 /* 68 */        0x5a, 0x5b, 0x58, 0x59, 0x5e, 0x5f, 0x5c, 0x5d, 
1043 /* 70 */        0x52, 0x52, 0x53, 0x53, 0x50, 0x50, 0x51, 0x51, 
1044 /* 78 */        0x56, 0x56, 0x57, 0x57, 0x54, 0x54, 0x55, 0x55, 
1045 /* 80 */        0xaa, 0xab, 0xa8, 0xa9, 0xae, 0xaf, 0xac, 0xad, 
1046 /* 88 */        0xa2, 0xa3, 0xa0, 0xa1, 0xa6, 0xa7, 0xa4, 0xa5, 
1047 /* 90 */        0xba, 0xbb, 0xb8, 0xb9, 0xbe, 0xbf, 0xbc, 0xbd, 
1048 /* 98 */        0xb2, 0xb3, 0xb0, 0xb1, 0xb6, 0xb7, 0xb4, 0xb5, 
1049 /* a0 */        0x8a, 0x8b, 0x88, 0x89, 0x8e, 0x8f, 0x8c, 0x8d, 
1050 /* a8 */        0x82, 0x83, 0x80, 0x81, 0x86, 0x87, 0x84, 0x85, 
1051 /* b0 */        0x9b, 0x98, 0x99, 0x9e, 0x9f, 0x9c, 0x9d, 0x92, 
1052 /* b8 */        0x93, 0x90, 0x91, 0x96, 0x97, 0x94, 0x95, 0xea, 
1053 /* c0 */        0xe8, 0xe9, 0xee, 0xef, 0xec, 0xed, 0xe2, 0xe3, 
1054 /* c8 */        0xe0, 0xe1, 0xe6, 0xe7, 0xe4, 0xe5, 0xfa, 0xf8, 
1055 /* d0 */        0xfe, 0xff, 0xfc, 0xfd, 0xf2, 0xf3, 0xf0, 0xf1, 
1056 /* d8 */        0xf6, 0xf7, 0xf4, 0xf5, 0xcb, 0xc9, 0xcf, 0xcd, 
1057 /* e0 */        0xc2, 0xc3, 0xc0, 0xc1, 0xc6, 0xc7, 0xc4, 0xc5, 
1058 /* e8 */        0xda, 0xdb, 0xd8, 0xd9, 0xde, 0xdf, 0xdc, 0xdd, 
1059 /* f0 */        0xd2, 0xd2, 0xd3, 0xd3, 0xd0, 0xd0, 0xd1, 0xd1, 
1060 /* f8 */        0xd6, 0xd6, 0xd7, 0xd7, 0xd4, 0xd4, 0xd5, 0xd5
1061 };
1062   
1063 /*---------------------------------------------------------------------------*
1064  *      reverse bits in a byte
1065  *---------------------------------------------------------------------------*/
1066 static unsigned char bitreverse[256] = {
1067 /* 00 */        0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0, 
1068 /* 08 */        0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0, 
1069 /* 10 */        0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8, 
1070 /* 18 */        0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8, 
1071 /* 20 */        0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4, 
1072 /* 28 */        0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4, 
1073 /* 30 */        0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec, 
1074 /* 38 */        0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc, 
1075 /* 40 */        0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2, 
1076 /* 48 */        0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2, 
1077 /* 50 */        0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea, 
1078 /* 58 */        0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa, 
1079 /* 60 */        0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6, 
1080 /* 68 */        0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6, 
1081 /* 70 */        0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee, 
1082 /* 78 */        0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe, 
1083 /* 80 */        0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1, 
1084 /* 88 */        0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1, 
1085 /* 90 */        0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9, 
1086 /* 98 */        0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9, 
1087 /* a0 */        0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5, 
1088 /* a8 */        0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5, 
1089 /* b0 */        0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed, 
1090 /* b8 */        0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd, 
1091 /* c0 */        0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3, 
1092 /* c8 */        0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3, 
1093 /* d0 */        0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb, 
1094 /* d8 */        0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb, 
1095 /* e0 */        0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7, 
1096 /* e8 */        0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7, 
1097 /* f0 */        0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef, 
1098 /* f8 */        0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff
1099 };
1100
1101 static u_char sinetab[8000] = { 213, 213, 213, 213, 213, 213, 213, 212,
1102 212, 212, 212, 212, 212, 215, 215, 215, 215, 215, 215, 214, 214,
1103 214, 214, 214, 214, 209, 209, 209, 209, 209, 209, 209, 208, 208,
1104 208, 208, 208, 208, 211, 211, 211, 211, 211, 211, 210, 210, 210,
1105 210, 210, 210, 221, 221, 221, 221, 221, 221, 220, 220, 220, 220,
1106 220, 220, 220, 223, 223, 223, 223, 223, 223, 222, 222, 222, 222,
1107 222, 222, 217, 217, 217, 217, 217, 217, 216, 216, 216, 216, 216,
1108 216, 216, 219, 219, 219, 219, 219, 219, 218, 218, 218, 218, 218,
1109 218, 197, 197, 197, 197, 197, 197, 196, 196, 196, 196, 196, 196,
1110 196, 199, 199, 199, 199, 199, 199, 198, 198, 198, 198, 198, 198,
1111 193, 193, 193, 193, 193, 193, 192, 192, 192, 192, 192, 192, 192,
1112 195, 195, 195, 195, 195, 195, 194, 194, 194, 194, 194, 194, 205,
1113 205, 205, 205, 205, 205, 204, 204, 204, 204, 204, 204, 204, 207,
1114 207, 207, 207, 207, 207, 206, 206, 206, 206, 206, 206, 201, 201,
1115 201, 201, 201, 201, 200, 200, 200, 200, 200, 200, 200, 203, 203,
1116 203, 203, 203, 203, 202, 202, 202, 202, 202, 202, 245, 245, 245,
1117 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 244, 244, 244,
1118 244, 244, 244, 244, 244, 244, 244, 244, 244, 247, 247, 247, 247,
1119 247, 247, 247, 247, 247, 247, 247, 247, 247, 246, 246, 246, 246,
1120 246, 246, 246, 246, 246, 246, 246, 246, 246, 241, 241, 241, 241,
1121 241, 241, 241, 241, 241, 241, 241, 241, 240, 240, 240, 240, 240,
1122 240, 240, 240, 240, 240, 240, 240, 240, 243, 243, 243, 243, 243,
1123 243, 243, 243, 243, 243, 243, 243, 243, 242, 242, 242, 242, 242,
1124 242, 242, 242, 242, 242, 242, 242, 242, 253, 253, 253, 253, 253,
1125 253, 253, 253, 253, 253, 253, 253, 253, 252, 252, 252, 252, 252,
1126 252, 252, 252, 252, 252, 252, 252, 255, 255, 255, 255, 255, 255,
1127 255, 255, 255, 255, 255, 255, 255, 254, 254, 254, 254, 254, 254,
1128 254, 254, 254, 254, 254, 254, 254, 249, 249, 249, 249, 249, 249,
1129 249, 249, 249, 249, 249, 249, 249, 248, 248, 248, 248, 248, 248,
1130 248, 248, 248, 248, 248, 248, 248, 251, 251, 251, 251, 251, 251,
1131 251, 251, 251, 251, 251, 251, 251, 250, 250, 250, 250, 250, 250,
1132 250, 250, 250, 250, 250, 250, 250, 229, 229, 229, 229, 229, 229,
1133 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229,
1134 229, 229, 229, 229, 229, 229, 229, 228, 228, 228, 228, 228, 228,
1135 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228,
1136 228, 228, 228, 228, 228, 228, 228, 228, 231, 231, 231, 231, 231,
1137 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231,
1138 231, 231, 231, 231, 231, 231, 231, 231, 231, 230, 230, 230, 230,
1139 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
1140 230, 230, 230, 230, 230, 230, 230, 230, 230, 225, 225, 225, 225,
1141 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225,
1142 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 224, 224,
1143 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224,
1144 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 227,
1145 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227,
1146 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227,
1147 227, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226,
1148 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226,
1149 226, 226, 226, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237,
1150 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237,
1151 237, 237, 237, 237, 237, 236, 236, 236, 236, 236, 236, 236, 236,
1152 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236,
1153 236, 236, 236, 236, 236, 236, 236, 236, 239, 239, 239, 239, 239,
1154 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239,
1155 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 238, 238,
1156 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238,
1157 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238,
1158 238, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233,
1159 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233,
1160 233, 233, 233, 233, 233, 232, 232, 232, 232, 232, 232, 232, 232,
1161 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232,
1162 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 235, 235, 235,
1163 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235,
1164 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235,
1165 235, 235, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234,
1166 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234,
1167 234, 234, 234, 234, 234, 234, 234, 149, 149, 149, 149, 149, 149,
1168 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1169 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1170 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1171 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1172 149, 149, 149, 149, 149, 149, 149, 148, 148, 148, 148, 148, 148,
1173 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1174 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1175 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1176 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1177 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 151, 151, 151,
1178 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1179 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1180 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1181 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1182 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1183 151, 151, 151, 151, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1184 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1185 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1186 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1187 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1188 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1189 150, 150, 150, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1190 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1191 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1192 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1193 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1194 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1195 145, 145, 145, 145, 145, 145, 145, 145, 144, 144, 144, 144, 144,
1196 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1197 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1198 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1199 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1200 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1201 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1202 144, 144, 144, 144, 144, 144, 144, 144, 144, 147, 147, 147, 147,
1203 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1204 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1205 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1206 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1207 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1208 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1209 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1210 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 146, 146, 146,
1211 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1212 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1213 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1214 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1215 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1216 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1217 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1218 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1219 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1220 146, 146, 146, 146, 146, 146, 157, 157, 157, 157, 157, 157, 157,
1221 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1222 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1223 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1224 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1225 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1226 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1227 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1228 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1229 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1230 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1231 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1232 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1233 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1234 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1235 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1236 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1237 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1238 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1239 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1240 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1241 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1242 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1243 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1244 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1245 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1246 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1247 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1248 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1249 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1250 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1251 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1252 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1253 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1254 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1255 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1256 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1257 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1258 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1259 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1260 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1261 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1262 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1263 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1264 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1265 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1266 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1267 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1268 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1269 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1270 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1271 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1272 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1273 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1274 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1275 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156, 156,
1276 156, 156, 156, 156, 156, 156, 156, 157, 157, 157, 157, 157, 157,
1277 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1278 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1279 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1280 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1281 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1282 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1283 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1284 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1285 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1286 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1287 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1288 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1289 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157, 157,
1290 157, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1291 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1292 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1293 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1294 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1295 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1296 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1297 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1298 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146,
1299 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 147, 147, 147,
1300 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1301 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1302 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1303 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1304 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1305 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1306 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147,
1307 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 147, 144, 144,
1308 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1309 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1310 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1311 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1312 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1313 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144,
1314 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 144, 145,
1315 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1316 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1317 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1318 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1319 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1320 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
1321 145, 145, 145, 145, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1322 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1323 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1324 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1325 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1326 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150, 150,
1327 150, 150, 150, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1328 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1329 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1330 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1331 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 151,
1332 151, 151, 151, 151, 151, 151, 151, 151, 151, 151, 148, 148, 148,
1333 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1334 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1335 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1336 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1337 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148, 148,
1338 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1339 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1340 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1341 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1342 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149, 149,
1343 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234,
1344 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234,
1345 234, 234, 234, 234, 234, 235, 235, 235, 235, 235, 235, 235, 235,
1346 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 235,
1347 235, 235, 235, 235, 235, 235, 235, 235, 235, 235, 232, 232, 232,
1348 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232,
1349 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232, 232,
1350 232, 232, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233,
1351 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233, 233,
1352 233, 233, 233, 233, 233, 233, 238, 238, 238, 238, 238, 238, 238,
1353 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238, 238,
1354 238, 238, 238, 238, 238, 238, 238, 238, 238, 239, 239, 239, 239,
1355 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239,
1356 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 239, 236,
1357 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236,
1358 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236, 236,
1359 236, 236, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237,
1360 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237,
1361 237, 237, 237, 237, 226, 226, 226, 226, 226, 226, 226, 226, 226,
1362 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226, 226,
1363 226, 226, 226, 226, 226, 226, 227, 227, 227, 227, 227, 227, 227,
1364 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227, 227,
1365 227, 227, 227, 227, 227, 227, 227, 227, 224, 224, 224, 224, 224,
1366 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224, 224,
1367 224, 224, 224, 224, 224, 224, 224, 224, 224, 225, 225, 225, 225,
1368 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225,
1369 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 225, 230, 230,
1370 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230,
1371 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 231, 231,
1372 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231,
1373 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 231, 228,
1374 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228,
1375 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228, 228,
1376 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229,
1377 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229,
1378 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250,
1379 251, 251, 251, 251, 251, 251, 251, 251, 251, 251, 251, 251, 251,
1380 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248,
1381 249, 249, 249, 249, 249, 249, 249, 249, 249, 249, 249, 249, 249,
1382 254, 254, 254, 254, 254, 254, 254, 254, 254, 254, 254, 254, 254,
1383 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
1384 252, 252, 252, 252, 252, 252, 252, 252, 252, 252, 252, 252, 253,
1385 253, 253, 253, 253, 253, 253, 253, 253, 253, 253, 253, 253, 242,
1386 242, 242, 242, 242, 242, 242, 242, 242, 242, 242, 242, 242, 243,
1387 243, 243, 243, 243, 243, 243, 243, 243, 243, 243, 243, 243, 240,
1388 240, 240, 240, 240, 240, 240, 240, 240, 240, 240, 240, 240, 241,
1389 241, 241, 241, 241, 241, 241, 241, 241, 241, 241, 241, 246, 246,
1390 246, 246, 246, 246, 246, 246, 246, 246, 246, 246, 246, 247, 247,
1391 247, 247, 247, 247, 247, 247, 247, 247, 247, 247, 247, 244, 244,
1392 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 245, 245, 245,
1393 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 202, 202, 202,
1394 202, 202, 202, 203, 203, 203, 203, 203, 203, 200, 200, 200, 200,
1395 200, 200, 200, 201, 201, 201, 201, 201, 201, 206, 206, 206, 206,
1396 206, 206, 207, 207, 207, 207, 207, 207, 204, 204, 204, 204, 204,
1397 204, 204, 205, 205, 205, 205, 205, 205, 194, 194, 194, 194, 194,
1398 194, 195, 195, 195, 195, 195, 195, 192, 192, 192, 192, 192, 192,
1399 192, 193, 193, 193, 193, 193, 193, 198, 198, 198, 198, 198, 198,
1400 199, 199, 199, 199, 199, 199, 196, 196, 196, 196, 196, 196, 196,
1401 197, 197, 197, 197, 197, 197, 218, 218, 218, 218, 218, 218, 219,
1402 219, 219, 219, 219, 219, 216, 216, 216, 216, 216, 216, 216, 217,
1403 217, 217, 217, 217, 217, 222, 222, 222, 222, 222, 222, 223, 223,
1404 223, 223, 223, 223, 220, 220, 220, 220, 220, 220, 220, 221, 221,
1405 221, 221, 221, 221, 210, 210, 210, 210, 210, 210, 211, 211, 211,
1406 211, 211, 211, 208, 208, 208, 208, 208, 208, 209, 209, 209, 209,
1407 209, 209, 209, 214, 214, 214, 214, 214, 214, 215, 215, 215, 215,
1408 215, 215, 212, 212, 212, 212, 212, 212, 213, 213, 213, 213, 213,
1409 213, 213, 90, 90, 90, 85, 85, 85, 85, 85, 85, 84, 84, 84, 84, 84,
1410 84, 87, 87, 87, 87, 87, 87, 86, 86, 86, 86, 86, 86, 81, 81, 81,
1411 81, 81, 81, 81, 80, 80, 80, 80, 80, 80, 83, 83, 83, 83, 83, 83,
1412 82, 82, 82, 82, 82, 82, 93, 93, 93, 93, 93, 93, 93, 92, 92, 92,
1413 92, 92, 92, 95, 95, 95, 95, 95, 95, 94, 94, 94, 94, 94, 94, 89,
1414 89, 89, 89, 89, 89, 88, 88, 88, 88, 88, 88, 88, 91, 91, 91, 91,
1415 91, 91, 90, 90, 90, 90, 90, 90, 69, 69, 69, 69, 69, 69, 68, 68,
1416 68, 68, 68, 68, 68, 71, 71, 71, 71, 71, 71, 70, 70, 70, 70, 70,
1417 70, 65, 65, 65, 65, 65, 65, 64, 64, 64, 64, 64, 64, 64, 67, 67,
1418 67, 67, 67, 67, 66, 66, 66, 66, 66, 66, 77, 77, 77, 77, 77, 77,
1419 76, 76, 76, 76, 76, 76, 76, 79, 79, 79, 79, 79, 79, 78, 78, 78,
1420 78, 78, 78, 73, 73, 73, 73, 73, 73, 73, 72, 72, 72, 72, 72, 72,
1421 75, 75, 75, 75, 75, 75, 74, 74, 74, 74, 74, 74, 117, 117, 117, 117,
1422 117, 117, 117, 117, 117, 117, 117, 117, 117, 116, 116, 116, 116,
1423 116, 116, 116, 116, 116, 116, 116, 116, 116, 119, 119, 119, 119,
1424 119, 119, 119, 119, 119, 119, 119, 119, 118, 118, 118, 118, 118,
1425 118, 118, 118, 118, 118, 118, 118, 118, 113, 113, 113, 113, 113,
1426 113, 113, 113, 113, 113, 113, 113, 113, 112, 112, 112, 112, 112,
1427 112, 112, 112, 112, 112, 112, 112, 115, 115, 115, 115, 115, 115,
1428 115, 115, 115, 115, 115, 115, 115, 114, 114, 114, 114, 114, 114,
1429 114, 114, 114, 114, 114, 114, 114, 125, 125, 125, 125, 125, 125,
1430 125, 125, 125, 125, 125, 125, 125, 124, 124, 124, 124, 124, 124,
1431 124, 124, 124, 124, 124, 124, 124, 127, 127, 127, 127, 127, 127,
1432 127, 127, 127, 127, 127, 127, 126, 126, 126, 126, 126, 126, 126,
1433 126, 126, 126, 126, 126, 126, 121, 121, 121, 121, 121, 121, 121,
1434 121, 121, 121, 121, 121, 121, 120, 120, 120, 120, 120, 120, 120,
1435 120, 120, 120, 120, 120, 120, 123, 123, 123, 123, 123, 123, 123,
1436 123, 123, 123, 123, 123, 123, 122, 122, 122, 122, 122, 122, 122,
1437 122, 122, 122, 122, 122, 122, 101, 101, 101, 101, 101, 101, 101,
1438 101, 101, 101, 101, 101, 101, 101, 101, 101, 101, 101, 101, 101,
1439 101, 101, 101, 101, 101, 101, 101, 100, 100, 100, 100, 100, 100,
1440 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100,
1441 100, 100, 100, 100, 100, 100, 100, 103, 103, 103, 103, 103, 103,
1442 103, 103, 103, 103, 103, 103, 103, 103, 103, 103, 103, 103, 103,
1443 103, 103, 103, 103, 103, 103, 103, 103, 102, 102, 102, 102, 102,
1444 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102,
1445 102, 102, 102, 102, 102, 102, 102, 102, 102, 97, 97, 97, 97, 97,
1446 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97,
1447 97, 97, 97, 97, 97, 97, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96,
1448 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96,
1449 96, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99,
1450 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 98, 98, 98,
1451 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98,
1452 98, 98, 98, 98, 98, 98, 98, 98, 98, 109, 109, 109, 109, 109, 109,
1453 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109,
1454 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 108, 108, 108,
1455 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108,
1456 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 111,
1457 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111,
1458 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111,
1459 111, 111, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110,
1460 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110,
1461 110, 110, 110, 110, 110, 110, 105, 105, 105, 105, 105, 105, 105,
1462 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105,
1463 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 104, 104, 104,
1464 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104,
1465 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104,
1466 104, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107,
1467 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107,
1468 107, 107, 107, 107, 107, 107, 106, 106, 106, 106, 106, 106, 106,
1469 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106,
1470 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 21,
1471 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1472 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1473 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1474 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1475 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1476 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1477 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1478 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1479 20, 20, 20, 20, 20, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1480 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1481 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1482 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1483 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 22, 22, 22,
1484 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1485 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1486 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1487 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1488 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 17, 17, 17, 17, 17, 17,
1489 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1490 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1491 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1492 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1493 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 16, 16,
1494 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1495 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1496 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1497 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1498 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1499 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 19, 19, 19, 19, 19, 19,
1500 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1501 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1502 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1503 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1504 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1505 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1506 19, 19, 19, 19, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1507 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1508 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1509 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1510 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1511 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1512 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1513 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1514 18, 18, 18, 18, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1515 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1516 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1517 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1518 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1519 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1520 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1521 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1522 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1523 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1524 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1525 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 28, 28, 28, 28, 28, 28,
1526 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1527 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1528 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1529 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1530 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1531 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1532 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1533 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1534 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1535 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1536 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1537 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1538 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1539 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1540 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1541 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1542 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1543 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1544 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1545 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1546 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1547 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1548 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1549 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1550 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1551 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1552 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1553 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1554 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1555 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1556 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1557 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,
1558 28, 28, 28, 28, 28, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1559 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1560 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1561 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1562 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1563 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1564 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1565 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1566 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1567 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1568 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29,
1569 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 18, 18, 18, 18, 18,
1570 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1571 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1572 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1573 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1574 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1575 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1576 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
1577 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19, 19,
1578 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1579 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1580 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1581 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1582 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1583 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19,
1584 19, 19, 19, 19, 19, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1585 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1586 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1587 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1588 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1589 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
1590 16, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1591 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1592 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1593 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1594 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17,
1595 17, 17, 17, 17, 17, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1596 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1597 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1598 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1599 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
1600 22, 22, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1601 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1602 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1603 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
1604 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 20, 20, 20, 20, 20, 20,
1605 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1606 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1607 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
1608 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 21,
1609 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1610 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1611 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1612 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1613 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106,
1614 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106, 106,
1615 106, 106, 106, 106, 106, 106, 107, 107, 107, 107, 107, 107, 107,
1616 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107,
1617 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 107, 104, 104,
1618 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104,
1619 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104, 104,
1620 104, 104, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105,
1621 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105, 105,
1622 105, 105, 105, 105, 105, 105, 110, 110, 110, 110, 110, 110, 110,
1623 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 110,
1624 110, 110, 110, 110, 110, 110, 110, 110, 110, 110, 111, 111, 111,
1625 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111,
1626 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, 111,
1627 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108,
1628 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, 108,
1629 108, 108, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109,
1630 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109, 109,
1631 109, 109, 109, 109, 109, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98,
1632 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98, 98,
1633 98, 98, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99,
1634 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 96, 96,
1635 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, 96,
1636 96, 96, 96, 96, 96, 96, 96, 96, 96, 97, 97, 97, 97, 97, 97, 97,
1637 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97, 97,
1638 97, 97, 97, 97, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102,
1639 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, 102,
1640 102, 102, 102, 102, 103, 103, 103, 103, 103, 103, 103, 103, 103,
1641 103, 103, 103, 103, 103, 103, 103, 103, 103, 103, 103, 103, 103,
1642 103, 103, 103, 103, 103, 100, 100, 100, 100, 100, 100, 100, 100,
1643 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, 100,
1644 100, 100, 100, 100, 100, 101, 101, 101, 101, 101, 101, 101, 101,
1645 101, 101, 101, 101, 101, 101, 101, 101, 101, 101, 101, 101, 101,
1646 101, 101, 101, 101, 101, 101, 122, 122, 122, 122, 122, 122, 122,
1647 122, 122, 122, 122, 122, 122, 123, 123, 123, 123, 123, 123, 123,
1648 123, 123, 123, 123, 123, 123, 120, 120, 120, 120, 120, 120, 120,
1649 120, 120, 120, 120, 120, 120, 121, 121, 121, 121, 121, 121, 121,
1650 121, 121, 121, 121, 121, 121, 126, 126, 126, 126, 126, 126, 126,
1651 126, 126, 126, 126, 126, 126, 127, 127, 127, 127, 127, 127, 127,
1652 127, 127, 127, 127, 127, 124, 124, 124, 124, 124, 124, 124, 124,
1653 124, 124, 124, 124, 124, 125, 125, 125, 125, 125, 125, 125, 125,
1654 125, 125, 125, 125, 125, 114, 114, 114, 114, 114, 114, 114, 114,
1655 114, 114, 114, 114, 114, 115, 115, 115, 115, 115, 115, 115, 115,
1656 115, 115, 115, 115, 115, 112, 112, 112, 112, 112, 112, 112, 112,
1657 112, 112, 112, 112, 113, 113, 113, 113, 113, 113, 113, 113, 113,
1658 113, 113, 113, 113, 118, 118, 118, 118, 118, 118, 118, 118, 118,
1659 118, 118, 118, 118, 119, 119, 119, 119, 119, 119, 119, 119, 119,
1660 119, 119, 119, 116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
1661 116, 116, 116, 117, 117, 117, 117, 117, 117, 117, 117, 117, 117,
1662 117, 117, 117, 74, 74, 74, 74, 74, 74, 75, 75, 75, 75, 75, 75, 72,
1663 72, 72, 72, 72, 72, 73, 73, 73, 73, 73, 73, 73, 78, 78, 78, 78,
1664 78, 78, 79, 79, 79, 79, 79, 79, 76, 76, 76, 76, 76, 76, 76, 77,
1665 77, 77, 77, 77, 77, 66, 66, 66, 66, 66, 66, 67, 67, 67, 67, 67,
1666 67, 64, 64, 64, 64, 64, 64, 64, 65, 65, 65, 65, 65, 65, 70, 70,
1667 70, 70, 70, 70, 71, 71, 71, 71, 71, 71, 68, 68, 68, 68, 68, 68,
1668 68, 69, 69, 69, 69, 69, 69, 90, 90, 90, 90, 90, 90, 91, 91, 91,
1669 91, 91, 91, 88, 88, 88, 88, 88, 88, 88, 89, 89, 89, 89, 89, 89,
1670 94, 94, 94, 94, 94, 94, 95, 95, 95, 95, 95, 95, 92, 92, 92, 92,
1671 92, 92, 93, 93, 93, 93, 93, 93, 93, 82, 82, 82, 82, 82, 82, 83,
1672 83, 83, 83, 83, 83, 80, 80, 80, 80, 80, 80, 81, 81, 81, 81, 81,
1673 81, 81, 86, 86, 86, 86, 86, 86, 87, 87, 87, 87, 87, 87, 84, 84,
1674 84, 84, 84, 84, 85, 85, 85, 85, 85, 85, 90, 90, 90 };
1675
1676 /*===========================================================================*/
1677
1678 #endif /* NI4BTEL > 0 */