00001 #ifndef _GPXE_UACCESS_H
00002 #define _GPXE_UACCESS_H
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 FILE_LICENCE ( GPL2_OR_LATER );
00023
00024 #include <stdint.h>
00025 #include <string.h>
00026 #include <gpxe/api.h>
00027 #include <config/ioapi.h>
00028
00029
00030
00031
00032
00033 typedef unsigned long userptr_t;
00034
00035
00036 #define UNULL ( ( userptr_t ) 0 )
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054 static inline __always_inline userptr_t
00055 trivial_virt_to_user ( volatile const void *addr ) {
00056 return ( ( userptr_t ) addr );
00057 }
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068 static inline __always_inline void *
00069 trivial_user_to_virt ( userptr_t userptr, off_t offset ) {
00070 return ( ( void * ) userptr + offset );
00071 }
00072
00073
00074
00075
00076
00077
00078
00079
00080 static inline __always_inline userptr_t
00081 trivial_userptr_add ( userptr_t userptr, off_t offset ) {
00082 return ( userptr + offset );
00083 }
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094 static inline __always_inline void
00095 trivial_memcpy_user ( userptr_t dest, off_t dest_off,
00096 userptr_t src, off_t src_off, size_t len ) {
00097 memcpy ( ( ( void * ) dest + dest_off ),
00098 ( ( void * ) src + src_off ), len );
00099 }
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109
00110 static inline __always_inline void
00111 trivial_memmove_user ( userptr_t dest, off_t dest_off,
00112 userptr_t src, off_t src_off, size_t len ) {
00113 memmove ( ( ( void * ) dest + dest_off ),
00114 ( ( void * ) src + src_off ), len );
00115 }
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125 static inline __always_inline void
00126 trivial_memset_user ( userptr_t buffer, off_t offset, int c, size_t len ) {
00127 memset ( ( ( void * ) buffer + offset ), c, len );
00128 }
00129
00130
00131
00132
00133
00134
00135
00136
00137 static inline __always_inline size_t
00138 trivial_strlen_user ( userptr_t buffer, off_t offset ) {
00139 return strlen ( ( void * ) buffer + offset );
00140 }
00141
00142
00143
00144
00145
00146
00147
00148
00149
00150
00151 static inline __always_inline off_t
00152 trivial_memchr_user ( userptr_t buffer, off_t offset, int c, size_t len ) {
00153 void *found;
00154
00155 found = memchr ( ( ( void * ) buffer + offset ), c, len );
00156 return ( found ? ( found - ( void * ) buffer ) : -1 );
00157 }
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168 #define UACCESS_INLINE( _subsys, _api_func ) \
00169 SINGLE_API_INLINE ( UACCESS_PREFIX_ ## _subsys, _api_func )
00170
00171
00172
00173
00174
00175
00176
00177
00178 #define PROVIDE_UACCESS( _subsys, _api_func, _func ) \
00179 PROVIDE_SINGLE_API ( UACCESS_PREFIX_ ## _subsys, _api_func, _func )
00180
00181
00182
00183
00184
00185
00186
00187 #define PROVIDE_UACCESS_INLINE( _subsys, _api_func ) \
00188 PROVIDE_SINGLE_API_INLINE ( UACCESS_PREFIX_ ## _subsys, _api_func )
00189
00190
00191 #include <gpxe/efi/efi_uaccess.h>
00192
00193
00194 #include <bits/uaccess.h>
00195
00196
00197
00198
00199
00200
00201
00202 userptr_t phys_to_user ( unsigned long phys_addr );
00203
00204
00205
00206
00207
00208
00209
00210
00211 unsigned long user_to_phys ( userptr_t userptr, off_t offset );
00212
00213
00214
00215
00216
00217
00218
00219 userptr_t virt_to_user ( volatile const void *addr );
00220
00221
00222
00223
00224
00225
00226
00227
00228
00229
00230 void * user_to_virt ( userptr_t userptr, off_t offset );
00231
00232
00233
00234
00235
00236
00237
00238
00239 userptr_t userptr_add ( userptr_t userptr, off_t offset );
00240
00241
00242
00243
00244
00245
00246
00247 static inline __always_inline unsigned long
00248 virt_to_phys ( volatile const void *addr ) {
00249 return user_to_phys ( virt_to_user ( addr ), 0 );
00250 }
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260 static inline __always_inline void * phys_to_virt ( unsigned long phys_addr ) {
00261 return user_to_virt ( phys_to_user ( phys_addr ), 0 );
00262 }
00263
00264
00265
00266
00267
00268
00269
00270
00271
00272
00273 void memcpy_user ( userptr_t dest, off_t dest_off,
00274 userptr_t src, off_t src_off, size_t len );
00275
00276
00277
00278
00279
00280
00281
00282
00283
00284 static inline __always_inline void
00285 copy_to_user ( userptr_t dest, off_t dest_off, const void *src, size_t len ) {
00286 memcpy_user ( dest, dest_off, virt_to_user ( src ), 0, len );
00287 }
00288
00289
00290
00291
00292
00293
00294
00295
00296
00297 static inline __always_inline void
00298 copy_from_user ( void *dest, userptr_t src, off_t src_off, size_t len ) {
00299 memcpy_user ( virt_to_user ( dest ), 0, src, src_off, len );
00300 }
00301
00302
00303
00304
00305
00306
00307
00308
00309
00310
00311 void memmove_user ( userptr_t dest, off_t dest_off,
00312 userptr_t src, off_t src_off, size_t len );
00313
00314
00315
00316
00317
00318
00319
00320
00321
00322 void memset_user ( userptr_t userptr, off_t offset, int c, size_t len );
00323
00324
00325
00326
00327
00328
00329
00330
00331 size_t strlen_user ( userptr_t userptr, off_t offset );
00332
00333
00334
00335
00336
00337
00338
00339
00340
00341
00342 off_t memchr_user ( userptr_t userptr, off_t offset, int c, size_t len );
00343
00344 #endif