⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 linuxrealtime.c

📁 Linux Distributed Replication Block Device
💻 C
📖 第 1 页 / 共 2 页
字号:
#if defined(WIN32) && defined(PERL_OBJECT) && !defined(PerlIO_exportFILE)#define PerlIO_exportFILE(fh,fl) (FILE*)(fh)#endif/* Modifications for newer Perl 5.005 releases */#if !defined(PERL_REVISION) || ((PERL_REVISION >= 5) && ((PERL_VERSION < 5) || ((PERL_VERSION == 5) && (PERL_SUBVERSION < 50))))#  ifndef PL_sv_yes#    define PL_sv_yes sv_yes#  endif#  ifndef PL_sv_undef#    define PL_sv_undef sv_undef#  endif#  ifndef PL_na#    define PL_na na#  endif#endif#include <stdlib.h>#ifdef __cplusplusextern "C" {#endif#define SWIG_OWNER 1#define SWIG_SHADOW 2/* Common SWIG API */#ifdef PERL_OBJECT#  define SWIG_ConvertPtr(obj, pp, type, flags) \     SWIG_Perl_ConvertPtr(pPerl, obj, pp, type, flags)#  define SWIG_NewPointerObj(p, type, flags) \     SWIG_Perl_NewPointerObj(pPerl, p, type, flags)#  define SWIG_MakePackedObj(sv, p, s, type)	\     SWIG_Perl_MakePackedObj(pPerl, sv, p, s, type)#  define SWIG_ConvertPacked(obj, p, s, type, flags) \     SWIG_Perl_ConvertPacked(pPerl, obj, p, s, type, flags)#else#  define SWIG_ConvertPtr(obj, pp, type, flags) \     SWIG_Perl_ConvertPtr(obj, pp, type, flags)#  define SWIG_NewPointerObj(p, type, flags) \     SWIG_Perl_NewPointerObj(p, type, flags)#  define SWIG_MakePackedObj(sv, p, s, type)	\     SWIG_Perl_MakePackedObj(sv, p, s, type )#  define SWIG_ConvertPacked(obj, p, s, type, flags) \     SWIG_Perl_ConvertPacked(obj, p, s, type, flags)#endif/* Perl-specific API */#ifdef PERL_OBJECT#  define SWIG_MakePtr(sv, ptr, type, flags) \     SWIG_Perl_MakePtr(pPerl, sv, ptr, type, flags)#  define SWIG_SetError(str) \     SWIG_Perl_SetError(pPerl, str)#else#  define SWIG_MakePtr(sv, ptr, type, flags) \     SWIG_Perl_MakePtr(sv, ptr, type, flags)#  define SWIG_SetError(str) \     SWIG_Perl_SetError(str)#  define SWIG_SetErrorSV(str) \     SWIG_Perl_SetErrorSV(str)#endif#define SWIG_SetErrorf SWIG_Perl_SetErrorf#ifdef PERL_OBJECT#  define SWIG_MAYBE_PERL_OBJECT CPerlObj *pPerl,#else#  define SWIG_MAYBE_PERL_OBJECT#endifstatic swig_type_info **SWIG_Perl_GetTypeListHandle() {  static void *type_pointer = (void *)0;  SV *pointer;  /* first check if pointer already created */  if (!type_pointer) {    pointer = get_sv("swig_runtime_data::type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, FALSE);    if (pointer && SvOK(pointer)) {      type_pointer = INT2PTR(swig_type_info **, SvIV(pointer));    }  }  return (swig_type_info **) type_pointer;}/*  Search for a swig_type_info structure */SWIGRUNTIMEINLINE swig_type_info *SWIG_Perl_GetTypeList() {  swig_type_info **tlh = SWIG_Perl_GetTypeListHandle();  return tlh ? *tlh : (swig_type_info*)0;}#define SWIG_Runtime_GetTypeList SWIG_Perl_GetTypeList static swig_type_info *SWIG_Perl_TypeCheckRV(SWIG_MAYBE_PERL_OBJECT SV *rv, swig_type_info *ty) {  swig_type_info *s;  if (!ty) return 0;        /* Void pointer */  s = ty->next;             /* First element always just a name */  do {    if (sv_derived_from(rv, (char *) s->name)) {      if (s == ty->next) return s;      /* Move s to the top of the linked list */      s->prev->next = s->next;      if (s->next) {        s->next->prev = s->prev;      }      /* Insert s as second element in the list */      s->next = ty->next;      if (ty->next) ty->next->prev = s;      ty->next = s;      s->prev = ty;      return s;    }    s = s->next;  } while (s && (s != ty->next));  return 0;}/* Function for getting a pointer value */static intSWIG_Perl_ConvertPtr(SWIG_MAYBE_PERL_OBJECT SV *sv, void **ptr, swig_type_info *_t, int flags) {  swig_type_info *tc;  void *voidptr = (void *)0;  /* If magical, apply more magic */  if (SvGMAGICAL(sv))    mg_get(sv);  /* Check to see if this is an object */  if (sv_isobject(sv)) {    SV *tsv = (SV*) SvRV(sv);    IV tmp = 0;    if ((SvTYPE(tsv) == SVt_PVHV)) {      MAGIC *mg;      if (SvMAGICAL(tsv)) {        mg = mg_find(tsv,'P');        if (mg) {          sv = mg->mg_obj;          if (sv_isobject(sv)) {            tmp = SvIV((SV*)SvRV(sv));          }        }      } else {        return -1;      }    } else {      tmp = SvIV((SV*)SvRV(sv));    }    voidptr = (void *)tmp;    if (!_t) {      *(ptr) = voidptr;      return 0;    }  } else if (! SvOK(sv)) {            /* Check for undef */    *(ptr) = (void *) 0;    return 0;  } else if (SvTYPE(sv) == SVt_RV) {  /* Check for NULL pointer */    *(ptr) = (void *) 0;    if (!SvROK(sv))      return 0;    else      return -1;  } else {                            /* Don't know what it is */    *(ptr) = (void *) 0;    return -1;  }  if (_t) {    /* Now see if the types match */    char *_c = HvNAME(SvSTASH(SvRV(sv)));    tc = SWIG_TypeCheck(_c,_t);    if (!tc) {      *ptr = voidptr;      return -1;    }    *ptr = SWIG_TypeCast(tc,voidptr);    return 0;  }  *ptr = voidptr;  return 0;}static voidSWIG_Perl_MakePtr(SWIG_MAYBE_PERL_OBJECT SV *sv, void *ptr, swig_type_info *t, int flags) {  if (ptr && (flags & SWIG_SHADOW)) {    SV *self;    SV *obj=newSV(0);    HV *hash=newHV();    HV *stash;    sv_setref_pv(obj, (char *) t->name, ptr);    stash=SvSTASH(SvRV(obj));    if (flags & SWIG_OWNER) {      HV *hv;      GV *gv=*(GV**)hv_fetch(stash, "OWNER", 5, TRUE);      if (!isGV(gv))        gv_init(gv, stash, "OWNER", 5, FALSE);      hv=GvHVn(gv);      hv_store_ent(hv, obj, newSViv(1), 0);    }    sv_magic((SV *)hash, (SV *)obj, 'P', Nullch, 0);    SvREFCNT_dec(obj);    self=newRV_noinc((SV *)hash);    sv_setsv(sv, self);    SvREFCNT_dec((SV *)self);    sv_bless(sv, stash);  }  else {    sv_setref_pv(sv, (char *) t->name, ptr);  }}static SWIGINLINE SV *SWIG_Perl_NewPointerObj(SWIG_MAYBE_PERL_OBJECT void *ptr, swig_type_info *t, int flags) {  SV *result = sv_newmortal();  SWIG_MakePtr(result, ptr, t, flags);  return result;}static void  SWIG_Perl_MakePackedObj(SWIG_MAYBE_PERL_OBJECT SV *sv, void *ptr, int sz, swig_type_info *type) {  char result[1024];  char *r = result;  if ((2*sz + 1 + strlen(type->name)) > 1000) return;  *(r++) = '_';  r = SWIG_PackData(r,ptr,sz);  strcpy(r,type->name);  sv_setpv(sv, result);}/* Convert a packed value value */static intSWIG_Perl_ConvertPacked(SWIG_MAYBE_PERL_OBJECT SV *obj, void *ptr, int sz, swig_type_info *ty, int flags) {  swig_type_info *tc;  const char  *c = 0;  if ((!obj) || (!SvOK(obj))) return -1;  c = SvPV(obj, PL_na);  /* Pointer values must start with leading underscore */  if (*c != '_') return -1;  c++;  c = SWIG_UnpackData(c,ptr,sz);  if (ty) {    tc = SWIG_TypeCheck(c,ty);    if (!tc) return -1;  }  return 0;}static SWIGINLINE voidSWIG_Perl_SetError(SWIG_MAYBE_PERL_OBJECT const char *error) {  if (error) sv_setpv(perl_get_sv("@", TRUE), error);}static SWIGINLINE voidSWIG_Perl_SetErrorSV(SWIG_MAYBE_PERL_OBJECT SV *error) {  if (error) sv_setsv(perl_get_sv("@", TRUE), error);}static voidSWIG_Perl_SetErrorf(const char *fmt, ...) {  va_list args;  va_start(args, fmt);  sv_vsetpvfn(perl_get_sv("@", TRUE), fmt, strlen(fmt), &args, Null(SV**), 0, Null(bool*));  va_end(args);}/* Macros for low-level exception handling */#define SWIG_fail       goto fail#define SWIG_croak(x)   { SWIG_SetError(x); goto fail; }#define SWIG_croakSV(x) { SWIG_SetErrorSV(x); goto fail; }/* most preprocessors do not support vararg macros :-( *//* #define SWIG_croakf(x...) { SWIG_SetErrorf(x); goto fail; } */typedef XS(SwigPerlWrapper);typedef SwigPerlWrapper *SwigPerlWrapperPtr;/* Structure for command table */typedef struct {  const char         *name;  SwigPerlWrapperPtr  wrapper;} swig_command_info;/* Information for constant table */#define SWIG_INT     1#define SWIG_FLOAT   2#define SWIG_STRING  3#define SWIG_POINTER 4#define SWIG_BINARY  5/* Constant information structure */typedef struct swig_constant_info {    int              type;    const char      *name;    long             lvalue;    double           dvalue;    void            *pvalue;    swig_type_info **ptype;} swig_constant_info;#ifdef __cplusplus}#endif/* Structure for variable table */typedef struct {  const char   *name;  SwigMagicFunc   set;  SwigMagicFunc   get;  swig_type_info  **type;} swig_variable_info;/* Magic variable code */#ifndef PERL_OBJECT#define swig_create_magic(s,a,b,c) _swig_create_magic(s,a,b,c)  #ifndef MULTIPLICITY     static void _swig_create_magic(SV *sv, char *name, int (*set)(SV *, MAGIC *), int (*get)(SV *,MAGIC *)) {  #else     static void _swig_create_magic(SV *sv, char *name, int (*set)(struct interpreter*, SV *, MAGIC *), int (*get)(struct interpreter*, SV *,MAGIC *)) {  #endif#else#  define swig_create_magic(s,a,b,c) _swig_create_magic(pPerl,s,a,b,c)static void _swig_create_magic(CPerlObj *pPerl, SV *sv, const char *name, int (CPerlObj::*set)(SV *, MAGIC *), int (CPerlObj::*get)(SV *, MAGIC *)) {#endif  MAGIC *mg;  sv_magic(sv,sv,'U',(char *) name,strlen(name));  mg = mg_find(sv,'U');  mg->mg_virtual = (MGVTBL *) malloc(sizeof(MGVTBL));  mg->mg_virtual->svt_get = (SwigMagicFuncHack) get;  mg->mg_virtual->svt_set = (SwigMagicFuncHack) set;  mg->mg_virtual->svt_len = 0;  mg->mg_virtual->svt_clear = 0;  mg->mg_virtual->svt_free = 0;}#ifdef do_open  #undef do_open#endif#ifdef do_close  #undef do_close#endif#ifdef scalar  #undef scalar#endif#ifdef list  #undef list#endif#ifdef apply  #undef apply#endif#ifdef convert  #undef convert#endif#ifdef Error  #undef Error#endif#ifdef form  #undef form#endif#ifdef vform  #undef vform#endif#ifdef LABEL  #undef LABEL#endif#ifdef METHOD  #undef METHOD#endif#ifdef Move  #undef Move#endif#ifdef yylex  #undef yylex#endif#ifdef yyparse  #undef yyparse#endif#ifdef yyerror  #undef yyerror#endif#ifdef invert  #undef invert#endif#ifdef ref  #undef ref#endif#ifdef ENTER  #undef ENTER#endif/* -------- TYPES TABLE (BEGIN) -------- */static swig_type_info *swig_types[1];/* -------- TYPES TABLE (END) -------- */#define SWIG_init    boot_LinuxRealTime#define SWIG_name   "LinuxRealTimec::boot_LinuxRealTime"#define SWIG_prefix "LinuxRealTimec::"#ifdef __cplusplusextern "C"#endif#ifndef PERL_OBJECT#ifndef MULTIPLICITYSWIGEXPORT(void) SWIG_init (CV* cv);#elseSWIGEXPORT(void) SWIG_init (pTHXo_ CV* cv);#endif#elseSWIGEXPORT(void) SWIG_init (CV *cv, CPerlObj *);#endif  void setRealTime(int prio);#ifdef PERL_OBJECT#define MAGIC_CLASS _wrap_LinuxRealTime_var::class _wrap_LinuxRealTime_var : public CPerlObj {public:#else#define MAGIC_CLASS#endifSWIGCLASS_STATIC int swig_magic_readonly(pTHX_ SV *sv, MAGIC *mg) {    MAGIC_PPERL    sv = sv; mg = mg;    croak("Value is read-only.");    return 0;}#ifdef PERL_OBJECT};#endif#ifdef __cplusplusextern "C" {#endifXS(_wrap_setRealTime) {    {        int arg1 ;        int argvi = 0;        dXSARGS;                if ((items < 1) || (items > 1)) {            SWIG_croak("Usage: setRealTime(prio);");        }        arg1 = (int) SvIV(ST(0));        setRealTime(arg1);                        XSRETURN(argvi);        fail:        ;    }    croak(Nullch);}/* -------- TYPE CONVERSION AND EQUIVALENCE RULES (BEGIN) -------- */static swig_type_info *swig_types_initial[] = {0};/* -------- TYPE CONVERSION AND EQUIVALENCE RULES (END) -------- */static swig_constant_info swig_constants[] = {{0,0,0,0,0,0}};#ifdef __cplusplus}#endifstatic swig_variable_info swig_variables[] = {{0,0,0,0}};static swig_command_info swig_commands[] = {{"LinuxRealTimec::setRealTime", _wrap_setRealTime},{0,0}};static void SWIG_Perl_SetTypeListHandle(swig_type_info **handle) {    SV *pointer;        /* create a new pointer */    pointer = get_sv("swig_runtime_data::type_pointer" SWIG_RUNTIME_VERSION SWIG_TYPE_TABLE_NAME, TRUE);    sv_setiv(pointer, PTR2IV(swig_type_list_handle));}static swig_type_info **SWIG_Perl_LookupTypePointer(swig_type_info **type_list_handle) {    swig_type_info **type_pointer;        /* first check if module already created */    type_pointer = SWIG_Perl_GetTypeListHandle();    if (type_pointer) {        return type_pointer;    } else {        /* create a new module and variable */        SWIG_Perl_SetTypeListHandle(type_list_handle);        return type_list_handle;    }}#ifdef __cplusplusextern "C"#endifXS(SWIG_init) {    dXSARGS;    int i;    static int _init = 0;    if (!_init) {        swig_type_list_handle = SWIG_Perl_LookupTypePointer(swig_type_list_handle);        for (i = 0; swig_types_initial[i]; i++) {            swig_types[i] = SWIG_TypeRegister(swig_types_initial[i]);        }	        _init = 1;    }        /* Install commands */    for (i = 0; swig_commands[i].name; i++) {        newXS((char*) swig_commands[i].name,swig_commands[i].wrapper, (char*)__FILE__);    }        /* Install variables */    for (i = 0; swig_variables[i].name; i++) {        SV *sv;        sv = perl_get_sv((char*) swig_variables[i].name, TRUE | 0x2);        if (swig_variables[i].type) {            SWIG_MakePtr(sv,(void *)1, *swig_variables[i].type,0);        } else {            sv_setiv(sv,(IV) 0);        }        swig_create_magic(sv, (char *) swig_variables[i].name, swig_variables[i].set, swig_variables[i].get);     }        /* Install constant */    for (i = 0; swig_constants[i].type; i++) {        SV *sv;        sv = perl_get_sv((char*)swig_constants[i].name, TRUE | 0x2);        switch(swig_constants[i].type) {            case SWIG_INT:            sv_setiv(sv, (IV) swig_constants[i].lvalue);            break;            case SWIG_FLOAT:            sv_setnv(sv, (double) swig_constants[i].dvalue);            break;            case SWIG_STRING:            sv_setpv(sv, (char *) swig_constants[i].pvalue);            break;            case SWIG_POINTER:            SWIG_MakePtr(sv, swig_constants[i].pvalue, *(swig_constants[i].ptype),0);            break;            case SWIG_BINARY:            SWIG_MakePackedObj(sv, swig_constants[i].pvalue, swig_constants[i].lvalue, *(swig_constants[i].ptype));            break;            default:            break;        }        SvREADONLY_on(sv);    }        ST(0) = &PL_sv_yes;    XSRETURN(1);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -