mirror of
https://github.com/elua/elua.git
synced 2025-01-08 20:56:17 +08:00
Merge branch 'master' of github.com:elua/elua
This commit is contained in:
commit
920b1c28cc
130
inc/eluarpc.h
130
inc/eluarpc.h
@ -1,65 +1,65 @@
|
|||||||
// Lightweight remote procedure call layer
|
// Lightweight remote procedure call layer
|
||||||
|
|
||||||
#ifndef __ELUARPC_H__
|
#ifndef __ELUARPC_H__
|
||||||
#define __ELUARPC_H__
|
#define __ELUARPC_H__
|
||||||
|
|
||||||
#include "type.h"
|
#include "type.h"
|
||||||
|
|
||||||
#define PACKET_SIG 0x18AFC284UL
|
#define PACKET_SIG 0x18AFC284UL
|
||||||
|
|
||||||
// Error codes
|
// Error codes
|
||||||
#define ELUARPC_OK 0
|
#define ELUARPC_OK 0
|
||||||
#define ELUARPC_ERR 1
|
#define ELUARPC_ERR 1
|
||||||
|
|
||||||
#define ELUARPC_OP_RES_MOD 0x80
|
#define ELUARPC_OP_RES_MOD 0x80
|
||||||
|
|
||||||
// Protocol constants
|
// Protocol constants
|
||||||
#define ELUARPC_START_OFFSET 4
|
#define ELUARPC_START_OFFSET 4
|
||||||
#define ELUARPC_START_SIZE 6
|
#define ELUARPC_START_SIZE 6
|
||||||
#define ELUARPC_END_SIZE 6
|
#define ELUARPC_END_SIZE 6
|
||||||
#define ELUARPC_RESPONSE_SIZE 1
|
#define ELUARPC_RESPONSE_SIZE 1
|
||||||
#define ELUARPC_PTR_HEADER_SIZE 6
|
#define ELUARPC_PTR_HEADER_SIZE 6
|
||||||
#define ELUARPC_SMALL_PTR_HEADER_SIZE 4
|
#define ELUARPC_SMALL_PTR_HEADER_SIZE 4
|
||||||
#define ELUARPC_U32_SIZE 5
|
#define ELUARPC_U32_SIZE 5
|
||||||
#define ELUARPC_U16_SIZE 3
|
#define ELUARPC_U16_SIZE 3
|
||||||
#define ELUARPC_U8_SIZE 2
|
#define ELUARPC_U8_SIZE 2
|
||||||
#define ELUARPC_OP_ID_SIZE 2
|
#define ELUARPC_OP_ID_SIZE 2
|
||||||
#define ELUARPC_READ_BUF_OFFSET ( ELUARPC_START_OFFSET + ELUARPC_START_SIZE + ELUARPC_RESPONSE_SIZE + ELUARPC_PTR_HEADER_SIZE )
|
#define ELUARPC_READ_BUF_OFFSET ( ELUARPC_START_OFFSET + ELUARPC_START_SIZE + ELUARPC_RESPONSE_SIZE + ELUARPC_PTR_HEADER_SIZE )
|
||||||
#define ELUARPC_SMALL_READ_BUF_OFFSET ( ELUARPC_START_OFFSET + ELUARPC_START_SIZE + ELUARPC_RESPONSE_SIZE + ELUARPC_SMALL_PTR_HEADER_SIZE )
|
#define ELUARPC_SMALL_READ_BUF_OFFSET ( ELUARPC_START_OFFSET + ELUARPC_START_SIZE + ELUARPC_RESPONSE_SIZE + ELUARPC_SMALL_PTR_HEADER_SIZE )
|
||||||
#define ELUARPC_WRITE_REQUEST_EXTRA ( ELUARPC_START_OFFSET + ELUARPC_START_SIZE + ELUARPC_OP_ID_SIZE + ELUARPC_U32_SIZE + ELUARPC_PTR_HEADER_SIZE + ELUARPC_END_SIZE )
|
#define ELUARPC_WRITE_REQUEST_EXTRA ( ELUARPC_START_OFFSET + ELUARPC_START_SIZE + ELUARPC_OP_ID_SIZE + ELUARPC_U32_SIZE + ELUARPC_PTR_HEADER_SIZE + ELUARPC_END_SIZE )
|
||||||
|
|
||||||
// Public interface
|
// Public interface
|
||||||
// Get request ID
|
// Get request ID
|
||||||
int eluarpc_get_request_id( const u8 *p, u8 *pid );
|
int eluarpc_get_request_id( const u8 *p, u8 *pid );
|
||||||
|
|
||||||
// Replace a flag with another flag
|
// Replace a flag with another flag
|
||||||
u32 eluarpc_replace_flag( u32 val, u32 origflag, u32 newflag );
|
u32 eluarpc_replace_flag( u32 val, u32 origflag, u32 newflag );
|
||||||
|
|
||||||
// Get packet size
|
// Get packet size
|
||||||
int eluarpc_get_packet_size( const u8 *p, u16 *psize );
|
int eluarpc_get_packet_size( const u8 *p, u16 *psize );
|
||||||
|
|
||||||
// Generic write function
|
// Generic write function
|
||||||
// Specifiers: o - operation
|
// Specifiers: o - operation
|
||||||
// r - response
|
// r - response
|
||||||
// c - u8
|
// c - u8
|
||||||
// h - u16
|
// h - u16
|
||||||
// l - u32
|
// l - u32
|
||||||
// i - int
|
// i - int
|
||||||
// L - s32
|
// L - s32
|
||||||
// p - ptr (given as ptr, len, len is an u32)
|
// p - ptr (given as ptr, len, len is an u32)
|
||||||
// P - ptr (given as ptr, len, len is an u16)
|
// P - ptr (given as ptr, len, len is an u16)
|
||||||
void eluarpc_gen_write( u8 *p, const char *fmt, ... );
|
void eluarpc_gen_write( u8 *p, const char *fmt, ... );
|
||||||
|
|
||||||
// Generic read function
|
// Generic read function
|
||||||
// Specifiers: o - operation
|
// Specifiers: o - operation
|
||||||
// r - response
|
// r - response
|
||||||
// c - u8
|
// c - u8
|
||||||
// h - u16
|
// h - u16
|
||||||
// l - u32
|
// l - u32
|
||||||
// L - s32
|
// L - s32
|
||||||
// i - int
|
// i - int
|
||||||
// p - ptr (returned as ptr, len, len is an u32)
|
// p - ptr (returned as ptr, len, len is an u32)
|
||||||
// P - ptr (returned as ptr, len, len is an u16)
|
// P - ptr (returned as ptr, len, len is an u16)
|
||||||
int eluarpc_gen_read( const u8 *p, const char *fmt, ... );
|
int eluarpc_gen_read( const u8 *p, const char *fmt, ... );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
718
src/eluarpc.c
718
src/eluarpc.c
@ -1,359 +1,359 @@
|
|||||||
// eLua RPC mechanism
|
// eLua RPC mechanism
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "type.h"
|
#include "type.h"
|
||||||
#include "eluarpc.h"
|
#include "eluarpc.h"
|
||||||
#include "rtype.h"
|
#include "rtype.h"
|
||||||
|
|
||||||
static u8 eluarpc_err_flag;
|
static u8 eluarpc_err_flag;
|
||||||
|
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
// Internal functions: fdata serialization
|
// Internal functions: fdata serialization
|
||||||
|
|
||||||
static u8 *eluarpc_write_u8( u8 *p, u8 fdata )
|
static u8 *eluarpc_write_u8( u8 *p, u8 fdata )
|
||||||
{
|
{
|
||||||
*p ++ = TYPE_INT_8;
|
*p ++ = TYPE_INT_8;
|
||||||
*p ++ = fdata;
|
*p ++ = fdata;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8* eluarpc_write_op_id( u8 *p, u8 fdata )
|
static u8* eluarpc_write_op_id( u8 *p, u8 fdata )
|
||||||
{
|
{
|
||||||
*p ++ = TYPE_OP_ID;
|
*p ++ = TYPE_OP_ID;
|
||||||
*p ++ = fdata;
|
*p ++ = fdata;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8 *eluarpc_write_u16( u8 *p, u16 fdata )
|
static u8 *eluarpc_write_u16( u8 *p, u16 fdata )
|
||||||
{
|
{
|
||||||
*p ++ = TYPE_INT_16;
|
*p ++ = TYPE_INT_16;
|
||||||
*p ++ = fdata & 0xFF;
|
*p ++ = fdata & 0xFF;
|
||||||
*p ++ = ( fdata >> 8 ) & 0xFF;
|
*p ++ = ( fdata >> 8 ) & 0xFF;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8 *eluarpc_write_u32( u8 *p, u32 fdata )
|
static u8 *eluarpc_write_u32( u8 *p, u32 fdata )
|
||||||
{
|
{
|
||||||
*p ++ = TYPE_INT_32;
|
*p ++ = TYPE_INT_32;
|
||||||
*p ++ = fdata & 0xFF;
|
*p ++ = fdata & 0xFF;
|
||||||
*p ++ = ( fdata >> 8 ) & 0xFF;
|
*p ++ = ( fdata >> 8 ) & 0xFF;
|
||||||
*p ++ = ( fdata >> 16 ) & 0xFF;
|
*p ++ = ( fdata >> 16 ) & 0xFF;
|
||||||
*p ++ = ( fdata >> 24 ) & 0xFF;
|
*p ++ = ( fdata >> 24 ) & 0xFF;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8 *eluarpc_write_ptr( u8 *p, const void* src, u32 srclen )
|
static u8 *eluarpc_write_ptr( u8 *p, const void* src, u32 srclen )
|
||||||
{
|
{
|
||||||
*p ++ = TYPE_PTR;
|
*p ++ = TYPE_PTR;
|
||||||
p = eluarpc_write_u32( p, srclen );
|
p = eluarpc_write_u32( p, srclen );
|
||||||
if( src )
|
if( src )
|
||||||
memcpy( p, src, srclen );
|
memcpy( p, src, srclen );
|
||||||
return p + srclen;
|
return p + srclen;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8 *eluarpc_write_small_ptr( u8 *p, const void* src, u16 srclen )
|
static u8 *eluarpc_write_small_ptr( u8 *p, const void* src, u16 srclen )
|
||||||
{
|
{
|
||||||
*p ++ = TYPE_SMALL_PTR;
|
*p ++ = TYPE_SMALL_PTR;
|
||||||
p = eluarpc_write_u16( p, srclen );
|
p = eluarpc_write_u16( p, srclen );
|
||||||
if( src )
|
if( src )
|
||||||
memcpy( p, src, srclen );
|
memcpy( p, src, srclen );
|
||||||
return p + srclen;
|
return p + srclen;
|
||||||
}
|
}
|
||||||
|
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
// Internal functions: fdata deserialization
|
// Internal functions: fdata deserialization
|
||||||
|
|
||||||
static const u8* eluarpc_read_expect( const u8 *p, u8 fdata )
|
static const u8* eluarpc_read_expect( const u8 *p, u8 fdata )
|
||||||
{
|
{
|
||||||
if( *p ++ != fdata )
|
if( *p ++ != fdata )
|
||||||
eluarpc_err_flag = ELUARPC_ERR;
|
eluarpc_err_flag = ELUARPC_ERR;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8 *eluarpc_read_u8( const u8 *p, u8 *pfdata )
|
static const u8 *eluarpc_read_u8( const u8 *p, u8 *pfdata )
|
||||||
{
|
{
|
||||||
p = eluarpc_read_expect( p, TYPE_INT_8 );
|
p = eluarpc_read_expect( p, TYPE_INT_8 );
|
||||||
*pfdata = *p ++;
|
*pfdata = *p ++;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8 *eluarpc_read_op_id( const u8 *p, u8 *pfdata )
|
static const u8 *eluarpc_read_op_id( const u8 *p, u8 *pfdata )
|
||||||
{
|
{
|
||||||
p = eluarpc_read_expect( p, TYPE_OP_ID );
|
p = eluarpc_read_expect( p, TYPE_OP_ID );
|
||||||
*pfdata = *p ++;
|
*pfdata = *p ++;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8* eluarpc_expect_op_id( const u8 *p, u8 id )
|
static const u8* eluarpc_expect_op_id( const u8 *p, u8 id )
|
||||||
{
|
{
|
||||||
u8 temp;
|
u8 temp;
|
||||||
|
|
||||||
p = eluarpc_read_expect( p, TYPE_OP_ID );
|
p = eluarpc_read_expect( p, TYPE_OP_ID );
|
||||||
temp = *p ++;
|
temp = *p ++;
|
||||||
if( temp != id )
|
if( temp != id )
|
||||||
eluarpc_err_flag = ELUARPC_ERR;
|
eluarpc_err_flag = ELUARPC_ERR;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8 *eluarpc_read_u16( const u8 *p, u16 *pfdata )
|
static const u8 *eluarpc_read_u16( const u8 *p, u16 *pfdata )
|
||||||
{
|
{
|
||||||
p = eluarpc_read_expect( p, TYPE_INT_16 );
|
p = eluarpc_read_expect( p, TYPE_INT_16 );
|
||||||
*pfdata = *p ++;
|
*pfdata = *p ++;
|
||||||
*pfdata |= ( u32 )( *p ++ ) << 8;
|
*pfdata |= ( u32 )( *p ++ ) << 8;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8 *eluarpc_read_u32( const u8 *p, u32 *pfdata )
|
static const u8 *eluarpc_read_u32( const u8 *p, u32 *pfdata )
|
||||||
{
|
{
|
||||||
p = eluarpc_read_expect( p, TYPE_INT_32 );
|
p = eluarpc_read_expect( p, TYPE_INT_32 );
|
||||||
*pfdata = *p ++;
|
*pfdata = *p ++;
|
||||||
*pfdata |= ( u32 )( *p ++ ) << 8;
|
*pfdata |= ( u32 )( *p ++ ) << 8;
|
||||||
*pfdata |= ( u32 )( *p ++ ) << 16;
|
*pfdata |= ( u32 )( *p ++ ) << 16;
|
||||||
*pfdata |= ( u32 )( *p ++ ) << 24;
|
*pfdata |= ( u32 )( *p ++ ) << 24;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8 *eluarpc_read_ptr( const u8 *p, void* src, u32 *psrclen )
|
static const u8 *eluarpc_read_ptr( const u8 *p, void* src, u32 *psrclen )
|
||||||
{
|
{
|
||||||
p = eluarpc_read_expect( p, TYPE_PTR );
|
p = eluarpc_read_expect( p, TYPE_PTR );
|
||||||
p = eluarpc_read_u32( p, psrclen );
|
p = eluarpc_read_u32( p, psrclen );
|
||||||
if( src && p )
|
if( src && p )
|
||||||
memcpy( src, p, *psrclen );
|
memcpy( src, p, *psrclen );
|
||||||
return p + *psrclen;
|
return p + *psrclen;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8 *eluarpc_read_small_ptr( const u8 *p, void* src, u16 *psrclen )
|
static const u8 *eluarpc_read_small_ptr( const u8 *p, void* src, u16 *psrclen )
|
||||||
{
|
{
|
||||||
p = eluarpc_read_expect( p, TYPE_SMALL_PTR );
|
p = eluarpc_read_expect( p, TYPE_SMALL_PTR );
|
||||||
p = eluarpc_read_u16( p, psrclen );
|
p = eluarpc_read_u16( p, psrclen );
|
||||||
if( src && p )
|
if( src && p )
|
||||||
memcpy( src, p, *psrclen );
|
memcpy( src, p, *psrclen );
|
||||||
return p + *psrclen;
|
return p + *psrclen;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
// Internal functions: packet handling (read and write)
|
// Internal functions: packet handling (read and write)
|
||||||
|
|
||||||
static u8* eluarpc_packet_ptr;
|
static u8* eluarpc_packet_ptr;
|
||||||
|
|
||||||
static u8* eluarpc_start_packet( u8 *p )
|
static u8* eluarpc_start_packet( u8 *p )
|
||||||
{
|
{
|
||||||
eluarpc_packet_ptr = p;
|
eluarpc_packet_ptr = p;
|
||||||
p += ELUARPC_START_OFFSET;
|
p += ELUARPC_START_OFFSET;
|
||||||
*p ++ = TYPE_START;
|
*p ++ = TYPE_START;
|
||||||
p = eluarpc_write_u32( p, PACKET_SIG );
|
p = eluarpc_write_u32( p, PACKET_SIG );
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8* eluarpc_end_packet( u8 *p )
|
static u8* eluarpc_end_packet( u8 *p )
|
||||||
{
|
{
|
||||||
u16 len;
|
u16 len;
|
||||||
|
|
||||||
*p ++ = TYPE_END;
|
*p ++ = TYPE_END;
|
||||||
p = eluarpc_write_u32( p, ~PACKET_SIG );
|
p = eluarpc_write_u32( p, ~PACKET_SIG );
|
||||||
len = p - eluarpc_packet_ptr;
|
len = p - eluarpc_packet_ptr;
|
||||||
p = eluarpc_packet_ptr;
|
p = eluarpc_packet_ptr;
|
||||||
*p ++ = TYPE_PKT_SIZE;
|
*p ++ = TYPE_PKT_SIZE;
|
||||||
eluarpc_write_u16( p, len );
|
eluarpc_write_u16( p, len );
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8* eluarpc_match_packet_start( const u8 *p )
|
static const u8* eluarpc_match_packet_start( const u8 *p )
|
||||||
{
|
{
|
||||||
u32 fdata;
|
u32 fdata;
|
||||||
|
|
||||||
p += ELUARPC_START_OFFSET;
|
p += ELUARPC_START_OFFSET;
|
||||||
p = eluarpc_read_expect( p, TYPE_START );
|
p = eluarpc_read_expect( p, TYPE_START );
|
||||||
p = eluarpc_read_u32( p, &fdata );
|
p = eluarpc_read_u32( p, &fdata );
|
||||||
if( fdata != PACKET_SIG )
|
if( fdata != PACKET_SIG )
|
||||||
eluarpc_err_flag = ELUARPC_ERR;
|
eluarpc_err_flag = ELUARPC_ERR;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const u8* eluarpc_match_packet_end( const u8 *p )
|
static const u8* eluarpc_match_packet_end( const u8 *p )
|
||||||
{
|
{
|
||||||
u32 fdata;
|
u32 fdata;
|
||||||
|
|
||||||
p = eluarpc_read_expect( p, TYPE_END );
|
p = eluarpc_read_expect( p, TYPE_END );
|
||||||
p = eluarpc_read_u32( p, &fdata );
|
p = eluarpc_read_u32( p, &fdata );
|
||||||
if( fdata != ~PACKET_SIG )
|
if( fdata != ~PACKET_SIG )
|
||||||
eluarpc_err_flag = ELUARPC_ERR;
|
eluarpc_err_flag = ELUARPC_ERR;
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
// Function serialization and deserialization
|
// Function serialization and deserialization
|
||||||
|
|
||||||
int eluarpc_get_request_id( const u8 *p, u8 *pid )
|
int eluarpc_get_request_id( const u8 *p, u8 *pid )
|
||||||
{
|
{
|
||||||
eluarpc_err_flag = ELUARPC_OK;
|
eluarpc_err_flag = ELUARPC_OK;
|
||||||
p = eluarpc_match_packet_start( p );
|
p = eluarpc_match_packet_start( p );
|
||||||
p = eluarpc_read_op_id( p, pid );
|
p = eluarpc_read_op_id( p, pid );
|
||||||
return eluarpc_err_flag;
|
return eluarpc_err_flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 eluarpc_replace_flag( u32 val, u32 origflag, u32 newflag )
|
u32 eluarpc_replace_flag( u32 val, u32 origflag, u32 newflag )
|
||||||
{
|
{
|
||||||
return ( val & origflag ) ? newflag : 0;
|
return ( val & origflag ) ? newflag : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int eluarpc_get_packet_size( const u8 *p, u16 *psize )
|
int eluarpc_get_packet_size( const u8 *p, u16 *psize )
|
||||||
{
|
{
|
||||||
eluarpc_err_flag = ELUARPC_OK;
|
eluarpc_err_flag = ELUARPC_OK;
|
||||||
p = eluarpc_read_expect( p, TYPE_PKT_SIZE );
|
p = eluarpc_read_expect( p, TYPE_PKT_SIZE );
|
||||||
p = eluarpc_read_u16( p, psize );
|
p = eluarpc_read_u16( p, psize );
|
||||||
return eluarpc_err_flag;
|
return eluarpc_err_flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generic write function
|
// Generic write function
|
||||||
// Specifiers: o - operation
|
// Specifiers: o - operation
|
||||||
// r - response
|
// r - response
|
||||||
// c - u8
|
// c - u8
|
||||||
// h - u16
|
// h - u16
|
||||||
// l - u32
|
// l - u32
|
||||||
// i - int
|
// i - int
|
||||||
// L - s32
|
// L - s32
|
||||||
// p - ptr (given as ptr, len, len is an u32)
|
// p - ptr (given as ptr, len, len is an u32)
|
||||||
// P - ptr (given as ptr, len, len is an u16)
|
// P - ptr (given as ptr, len, len is an u16)
|
||||||
void eluarpc_gen_write( u8 *p, const char *fmt, ... )
|
void eluarpc_gen_write( u8 *p, const char *fmt, ... )
|
||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
const void *ptr;
|
const void *ptr;
|
||||||
u32 ptrlen;
|
u32 ptrlen;
|
||||||
|
|
||||||
va_start( ap, fmt );
|
va_start( ap, fmt );
|
||||||
p = eluarpc_start_packet( p );
|
p = eluarpc_start_packet( p );
|
||||||
while( *fmt )
|
while( *fmt )
|
||||||
switch( *fmt ++ )
|
switch( *fmt ++ )
|
||||||
{
|
{
|
||||||
case 'o':
|
case 'o':
|
||||||
p = eluarpc_write_op_id( p, va_arg( ap, int ) );
|
p = eluarpc_write_op_id( p, va_arg( ap, int ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'r':
|
case 'r':
|
||||||
*p++ = ELUARPC_OP_RES_MOD | ( u8 )va_arg( ap, int );
|
*p++ = ELUARPC_OP_RES_MOD | ( u8 )va_arg( ap, int );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'c':
|
case 'c':
|
||||||
p = eluarpc_write_u8( p, ( u8 )va_arg( ap, int ) );
|
p = eluarpc_write_u8( p, ( u8 )va_arg( ap, int ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'h':
|
case 'h':
|
||||||
p = eluarpc_write_u16( p, ( u16 )va_arg( ap, int ) );
|
p = eluarpc_write_u16( p, ( u16 )va_arg( ap, int ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'i':
|
case 'i':
|
||||||
p = eluarpc_write_u32( p, ( u32 )va_arg( ap, int ) );
|
p = eluarpc_write_u32( p, ( u32 )va_arg( ap, int ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'l':
|
case 'l':
|
||||||
p = eluarpc_write_u32( p, ( u32 )va_arg( ap, u32 ) );
|
p = eluarpc_write_u32( p, ( u32 )va_arg( ap, u32 ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'L':
|
case 'L':
|
||||||
p = eluarpc_write_u32( p, ( u32 )va_arg( ap, s32 ) );
|
p = eluarpc_write_u32( p, ( u32 )va_arg( ap, s32 ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'p':
|
case 'p':
|
||||||
ptr = va_arg( ap, void* );
|
ptr = va_arg( ap, void* );
|
||||||
ptrlen = ( u32 )va_arg( ap, u32 );
|
ptrlen = ( u32 )va_arg( ap, u32 );
|
||||||
p = eluarpc_write_ptr( p, ptr, ptrlen );
|
p = eluarpc_write_ptr( p, ptr, ptrlen );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'P':
|
case 'P':
|
||||||
ptr = va_arg( ap, void * );
|
ptr = va_arg( ap, void * );
|
||||||
ptrlen = ( u16 )va_arg( ap, int );
|
ptrlen = ( u16 )va_arg( ap, int );
|
||||||
p = eluarpc_write_small_ptr( p, ptr, ptrlen );
|
p = eluarpc_write_small_ptr( p, ptr, ptrlen );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
eluarpc_end_packet( p );
|
eluarpc_end_packet( p );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generic read function
|
// Generic read function
|
||||||
// Specifiers: o - operation
|
// Specifiers: o - operation
|
||||||
// r - response
|
// r - response
|
||||||
// c - u8
|
// c - u8
|
||||||
// h - u16
|
// h - u16
|
||||||
// l - u32
|
// l - u32
|
||||||
// L - s32
|
// L - s32
|
||||||
// i - int
|
// i - int
|
||||||
// p - ptr (returned as ptr, len, len is an u32)
|
// p - ptr (returned as ptr, len, len is an u32)
|
||||||
// P - ptr (returned as ptr, len, len is an u16)
|
// P - ptr (returned as ptr, len, len is an u16)
|
||||||
int eluarpc_gen_read( const u8 *p, const char *fmt, ... )
|
int eluarpc_gen_read( const u8 *p, const char *fmt, ... )
|
||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
const void *pptr;
|
const void *pptr;
|
||||||
u32 *ptrlen;
|
u32 *ptrlen;
|
||||||
const u8 *tempptr;
|
const u8 *tempptr;
|
||||||
u32 temp32;
|
u32 temp32;
|
||||||
u16 temp16;
|
u16 temp16;
|
||||||
u16 *sptrlen;
|
u16 *sptrlen;
|
||||||
|
|
||||||
va_start( ap, fmt );
|
va_start( ap, fmt );
|
||||||
eluarpc_err_flag = ELUARPC_OK;
|
eluarpc_err_flag = ELUARPC_OK;
|
||||||
p = eluarpc_match_packet_start( p );
|
p = eluarpc_match_packet_start( p );
|
||||||
while( *fmt )
|
while( *fmt )
|
||||||
switch( *fmt ++ )
|
switch( *fmt ++ )
|
||||||
{
|
{
|
||||||
case 'o':
|
case 'o':
|
||||||
p = eluarpc_expect_op_id( p, va_arg( ap, int ) );
|
p = eluarpc_expect_op_id( p, va_arg( ap, int ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'r':
|
case 'r':
|
||||||
p = eluarpc_read_expect( p, ELUARPC_OP_RES_MOD | ( u8 )va_arg( ap, int ) );
|
p = eluarpc_read_expect( p, ELUARPC_OP_RES_MOD | ( u8 )va_arg( ap, int ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'c':
|
case 'c':
|
||||||
p = eluarpc_read_u8( p, ( u8* )va_arg( ap, void * ) );
|
p = eluarpc_read_u8( p, ( u8* )va_arg( ap, void * ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'h':
|
case 'h':
|
||||||
p = eluarpc_read_u16( p, ( u16* )va_arg( ap, void * ) );
|
p = eluarpc_read_u16( p, ( u16* )va_arg( ap, void * ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'l':
|
case 'l':
|
||||||
p = eluarpc_read_u32( p, ( u32* )va_arg( ap, void * ) );
|
p = eluarpc_read_u32( p, ( u32* )va_arg( ap, void * ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'L':
|
case 'L':
|
||||||
p = eluarpc_read_u32( p, &temp32 );
|
p = eluarpc_read_u32( p, &temp32 );
|
||||||
*( s32 *)va_arg( ap, void * ) = ( s32 )temp32;
|
*( s32 *)va_arg( ap, void * ) = ( s32 )temp32;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'i':
|
case 'i':
|
||||||
p = eluarpc_read_u32( p, &temp32 );
|
p = eluarpc_read_u32( p, &temp32 );
|
||||||
*( int* )va_arg( ap, void * ) = ( int )temp32;
|
*( int* )va_arg( ap, void * ) = ( int )temp32;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'p':
|
case 'p':
|
||||||
pptr = va_arg( ap, void** );
|
pptr = va_arg( ap, void** );
|
||||||
ptrlen = ( u32* )va_arg( ap, void* );
|
ptrlen = ( u32* )va_arg( ap, void* );
|
||||||
tempptr = p;
|
tempptr = p;
|
||||||
p = eluarpc_read_ptr( p, NULL, &temp32 );
|
p = eluarpc_read_ptr( p, NULL, &temp32 );
|
||||||
if( p == tempptr + ELUARPC_PTR_HEADER_SIZE )
|
if( p == tempptr + ELUARPC_PTR_HEADER_SIZE )
|
||||||
*( const u8** )pptr = NULL;
|
*( const u8** )pptr = NULL;
|
||||||
else
|
else
|
||||||
*( const u8** )pptr = tempptr + ELUARPC_PTR_HEADER_SIZE;
|
*( const u8** )pptr = tempptr + ELUARPC_PTR_HEADER_SIZE;
|
||||||
if( ptrlen )
|
if( ptrlen )
|
||||||
*ptrlen = temp32;
|
*ptrlen = temp32;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'P':
|
case 'P':
|
||||||
pptr = va_arg( ap, void** );
|
pptr = va_arg( ap, void** );
|
||||||
sptrlen = ( u16* )va_arg( ap, void* );
|
sptrlen = ( u16* )va_arg( ap, void* );
|
||||||
tempptr = p;
|
tempptr = p;
|
||||||
p = eluarpc_read_small_ptr( p, NULL, &temp16 );
|
p = eluarpc_read_small_ptr( p, NULL, &temp16 );
|
||||||
if( p == tempptr + ELUARPC_SMALL_PTR_HEADER_SIZE )
|
if( p == tempptr + ELUARPC_SMALL_PTR_HEADER_SIZE )
|
||||||
*( const u8** )pptr = NULL;
|
*( const u8** )pptr = NULL;
|
||||||
else
|
else
|
||||||
*( const u8** )pptr = tempptr + ELUARPC_SMALL_PTR_HEADER_SIZE;
|
*( const u8** )pptr = tempptr + ELUARPC_SMALL_PTR_HEADER_SIZE;
|
||||||
if( sptrlen )
|
if( sptrlen )
|
||||||
*sptrlen = temp16;
|
*sptrlen = temp16;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
eluarpc_match_packet_end( p );
|
eluarpc_match_packet_end( p );
|
||||||
return eluarpc_err_flag;
|
return eluarpc_err_flag;
|
||||||
}
|
}
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -413,7 +413,7 @@ typedef struct _AVR32_TxTdDescriptor {
|
|||||||
*
|
*
|
||||||
* \return TRUE if success, FALSE otherwise.
|
* \return TRUE if success, FALSE otherwise.
|
||||||
*/
|
*/
|
||||||
extern Bool xMACBInit(volatile avr32_macb_t *macb);
|
extern Bool xMACBInit(volatile avr32_macb_t *macb);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Send ulLength bytes from pcFrom. This copies the buffer to one of the
|
* \brief Send ulLength bytes from pcFrom. This copies the buffer to one of the
|
||||||
@ -428,7 +428,7 @@ extern Bool xMACBInit(volatile avr32_macb_t *macb);
|
|||||||
*
|
*
|
||||||
* \return length sent.
|
* \return length sent.
|
||||||
*/
|
*/
|
||||||
extern long lMACBSend(volatile avr32_macb_t *macb, const void *pvFrom, unsigned long ulLength, long lEndOfFrame);
|
extern long lMACBSend(volatile avr32_macb_t *macb, const void *pvFrom, unsigned long ulLength, long lEndOfFrame);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Frames can be read from the MACB in multiple sections.
|
* \brief Frames can be read from the MACB in multiple sections.
|
||||||
@ -441,21 +441,21 @@ extern long lMACBSend(volatile avr32_macb_t *macb, const void *pvFrom, unsigned
|
|||||||
* \param ulSectionLength Length of the buffer
|
* \param ulSectionLength Length of the buffer
|
||||||
* \param ulTotalFrameLength Length of the frame
|
* \param ulTotalFrameLength Length of the frame
|
||||||
*/
|
*/
|
||||||
extern void vMACBRead(void *pvTo, unsigned long ulSectionLength, unsigned long ulTotalFrameLength);
|
extern void vMACBRead(void *pvTo, unsigned long ulSectionLength, unsigned long ulTotalFrameLength);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Flush the current received packet.
|
* \brief Flush the current received packet.
|
||||||
*
|
*
|
||||||
* \param ulTotalFrameLength Length of the packet to flush
|
* \param ulTotalFrameLength Length of the packet to flush
|
||||||
*/
|
*/
|
||||||
extern void vMACBFlushCurrentPacket(unsigned long ulTotalFrameLength);
|
extern void vMACBFlushCurrentPacket(unsigned long ulTotalFrameLength);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Called by the Tx interrupt, this function traverses the buffers used to
|
* \brief Called by the Tx interrupt, this function traverses the buffers used to
|
||||||
* hold the frame that has just completed transmission and marks each as
|
* hold the frame that has just completed transmission and marks each as
|
||||||
* free again.
|
* free again.
|
||||||
*/
|
*/
|
||||||
extern void vClearMACBTxBuffer(void);
|
extern void vClearMACBTxBuffer(void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Suspend on a semaphore waiting either for the semaphore to be obtained
|
* \brief Suspend on a semaphore waiting either for the semaphore to be obtained
|
||||||
@ -465,28 +465,28 @@ extern void vClearMACBTxBuffer(void);
|
|||||||
* \param ulTimeOut time to wait for an input
|
* \param ulTimeOut time to wait for an input
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
extern void vMACBWaitForInput(unsigned long ulTimeOut);
|
extern void vMACBWaitForInput(unsigned long ulTimeOut);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Function to get length of the next frame in the receive buffers
|
* \brief Function to get length of the next frame in the receive buffers
|
||||||
*
|
*
|
||||||
* \return the length of the next frame in the receive buffers.
|
* \return the length of the next frame in the receive buffers.
|
||||||
*/
|
*/
|
||||||
extern unsigned long ulMACBInputLength(void);
|
extern unsigned long ulMACBInputLength(void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Set the MACB Physical address (SA1B & SA1T registers).
|
* \brief Set the MACB Physical address (SA1B & SA1T registers).
|
||||||
*
|
*
|
||||||
* \param *MACAddress the MAC address to set.
|
* \param *MACAddress the MAC address to set.
|
||||||
*/
|
*/
|
||||||
extern void vMACBSetMACAddress(const unsigned char *MACAddress);
|
extern void vMACBSetMACAddress(const unsigned char *MACAddress);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Disable MACB operations (Tx and Rx).
|
* \brief Disable MACB operations (Tx and Rx).
|
||||||
*
|
*
|
||||||
* \param *macb Base address of the MACB
|
* \param *macb Base address of the MACB
|
||||||
*/
|
*/
|
||||||
extern void vDisableMACBOperations(volatile avr32_macb_t *macb);
|
extern void vDisableMACBOperations(volatile avr32_macb_t *macb);
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user