/usr/include/rtai/rtai_nam2num.h is in librtai-dev 3.9.1-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 | /**
* @ingroup shm
* @ingroup lxrt
* @ingroup tasklets
* @file
*
* Conversion between characters strings and unsigned long identifiers.
*
* Convert a 6 characters string to un unsigned long, and vice versa, to be used
* as an identifier for RTAI services symmetrically available in user and kernel
* space, e.g. @ref shm "shared memory" and @ref lxrt "LXRT and LXRT-INFORMED".
*
* @author Paolo Mantegazza
*
* @note Copyright © 1999-2003 Paolo Mantegazza <mantegazza@aero.polimi.it>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef _RTAI_NAM2NUM_H
#define _RTAI_NAM2NUM_H
#include <rtai_types.h>
#ifdef __KERNEL__
#define NAM2NUM_PROTO(type, name, arglist) static inline type name arglist
#else
#define NAM2NUM_PROTO RTAI_PROTO
#endif
/**
* Convert a 6 characters string to an unsigned long.
*
* Converts a 6 characters string name containing an alpha numeric
* identifier to its corresponding unsigned long identifier.
*
* @param name is the name to be converted.
*
* Allowed characters are:
* - english letters (no difference between upper and lower case);
* - decimal digits;
* - underscore (_) and another character of your choice. The latter will be
* always converted back to a $ by num2nam().
*
* @return the unsigned long associated with @a name.
*/
NAM2NUM_PROTO(unsigned long, nam2num, (const char *name))
{
unsigned long retval = 0;
int c, i;
for (i = 0; i < 6; i++) {
if (!(c = name[i]))
break;
if (c >= 'a' && c <= 'z') {
c += (11 - 'a');
} else if (c >= 'A' && c <= 'Z') {
c += (11 - 'A');
} else if (c >= '0' && c <= '9') {
c -= ('0' - 1);
} else {
c = c == '_' ? 37 : 38;
}
retval = retval*39 + c;
}
if (i > 0)
return retval + 2;
else
return 0xFFFFFFFF;
}
/**
* Convert an unsigned long to a 6 characters string.
*
* @param num is the unsigned long identifier whose alphanumeric name string has
* to be evaluated;
*
* @param name is a pointer to a 6 characters buffer where the identifier will
* be returned.
*/
NAM2NUM_PROTO(void, num2nam, (unsigned long num, char *name))
{
int c, i, k, q;
if (num == 0xFFFFFFFF) {
name[0] = 0;
return;
}
i = 5;
num -= 2;
while (num && i >= 0) {
q = num/39;
c = num - q*39;
num = q;
if ( c < 37) {
name[i--] = c > 10 ? c + 'A' - 11 : c + '0' - 1;
} else {
name[i--] = c == 37 ? '_' : '$';
}
}
for (k = 0; i < 5; k++) {
name[k] = name[++i];
}
name[k] = 0;
}
#endif /* !_RTAI_NAM2NUM_H */
|