1/* Definitions for locale archive handling.
2 Copyright (C) 2002-2022 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
4
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
9
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
14
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <https://www.gnu.org/licenses/>. */
18
19#ifndef _LOCARCHIVE_H
20#define _LOCARCHIVE_H 1
21
22#include <stdint.h>
23
24
25#define AR_MAGIC 0xde020109
26
27struct locarhead
28{
29 uint32_t magic;
30 /* Serial number. */
31 uint32_t serial;
32 /* Name hash table. */
33 uint32_t namehash_offset;
34 uint32_t namehash_used;
35 uint32_t namehash_size;
36 /* String table. */
37 uint32_t string_offset;
38 uint32_t string_used;
39 uint32_t string_size;
40 /* Table with locale records. */
41 uint32_t locrectab_offset;
42 uint32_t locrectab_used;
43 uint32_t locrectab_size;
44 /* MD5 sum hash table. */
45 uint32_t sumhash_offset;
46 uint32_t sumhash_used;
47 uint32_t sumhash_size;
48};
49
50
51struct namehashent
52{
53 /* Hash value of the name. */
54 uint32_t hashval;
55 /* Offset of the name in the string table. */
56 uint32_t name_offset;
57 /* Offset of the locale record. */
58 uint32_t locrec_offset;
59};
60
61
62struct sumhashent
63{
64 /* MD5 sum. */
65 char sum[16];
66 /* Offset of the file in the archive. */
67 uint32_t file_offset;
68};
69
70struct locrecent
71{
72 uint32_t refs; /* # of namehashent records that point here */
73 struct
74 {
75 uint32_t offset;
76 uint32_t len;
77 } record[__LC_LAST];
78};
79
80
81struct locarhandle
82{
83 /* Full path to the locale archive file. */
84 const char *fname;
85 int fd;
86 void *addr;
87 size_t mmaped;
88 size_t reserved;
89 /* If this mmap required adjustment (such as re-aligning), then this is the
90 real address that was returned from mmap and thus should be passed to the
91 munmap call. The addr field above is the first usable address. */
92 void *mmap_base;
93 /* Same as above for mmap_base vs addr, but this is the real length of the
94 map rather than the usable (which is what reserved represents). */
95 size_t mmap_len;
96};
97
98
99/* In memory data for the locales with their checksums. */
100typedef struct locale_category_data
101{
102 off64_t size;
103 void *addr;
104 char sum[16];
105} locale_data_t[__LC_LAST];
106
107#endif /* locarchive.h */
108

source code of glibc/locale/locarchive.h