Ignore:
Timestamp:
Jan 2, 2009, 7:56:06 PM (12 years ago)
Author:
charles
Message:

(trunk libT) avoid some unnecessary memory fragmentation... for composited objects that have a tr_bandwidth, contain the it directly rather than a pointer to one allocated elsewhere on the heap.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/libtransmission/peer-io.h

    r7579 r7580  
    2727
    2828#include "transmission.h"
     29#include "bandwidth.h"
    2930#include "list.h" /* __tr_list */
    3031#include "net.h" /* tr_address */
     
    5859typedef struct tr_peerIo
    5960{
    60     tr_bool            isEncrypted;
    61     tr_bool            isIncoming;
    62     tr_bool            peerIdIsSet;
    63     tr_bool            extendedProtocolSupported;
    64     tr_bool            fastExtensionSupported;
    65 
    66     int                magicNumber;
    67 
    68     uint8_t            encryptionMode;
    69     tr_port            port;
    70     int                socket;
    71 
    72     uint8_t            peerId[SHA_DIGEST_LENGTH];
    73     time_t             timeCreated;
    74 
    75     tr_session       * session;
    76 
    77     tr_address         addr;
    78 
    79     tr_can_read_cb     canRead;
    80     tr_did_write_cb    didWrite;
    81     tr_net_error_cb    gotError;
    82     void *             userData;
    83 
    84     struct tr_bandwidth * bandwidth;
     61    tr_bool               isEncrypted;
     62    tr_bool               isIncoming;
     63    tr_bool               peerIdIsSet;
     64    tr_bool               extendedProtocolSupported;
     65    tr_bool               fastExtensionSupported;
     66
     67    int                   magicNumber;
     68
     69    uint8_t               encryptionMode;
     70    tr_port               port;
     71    int                   socket;
     72
     73    uint8_t               peerId[SHA_DIGEST_LENGTH];
     74    time_t                timeCreated;
     75
     76    tr_session          * session;
     77
     78    tr_address            addr;
     79
     80    tr_can_read_cb        canRead;
     81    tr_did_write_cb       didWrite;
     82    tr_net_error_cb       gotError;
     83    void *                userData;
     84
     85    struct tr_bandwidth   bandwidth;
    8586    struct tr_crypto    * crypto;
    8687
    87     struct evbuffer  * inbuf;
    88     struct evbuffer  * outbuf;
    89     struct __tr_list   outbuf_datatypes; /* struct tr_datatype */
    90 
    91     struct event       event_read;
    92     struct event       event_write;
     88    struct evbuffer     * inbuf;
     89    struct evbuffer     * outbuf;
     90    struct __tr_list      outbuf_datatypes; /* struct tr_datatype */
     91
     92    struct event          event_read;
     93    struct event          event_write;
    9394}
    9495tr_peerIo;
     
    99100
    100101tr_peerIo*  tr_peerIoNewOutgoing( tr_session              * session,
     102                                  struct tr_bandwidth     * parent,
    101103                                  const struct tr_address * addr,
    102104                                  tr_port                   port,
     
    104106
    105107tr_peerIo*  tr_peerIoNewIncoming( tr_session              * session,
     108                                  struct tr_bandwidth     * parent,
    106109                                  const struct tr_address * addr,
    107110                                  tr_port                   port,
     
    119122void        tr_peerIoEnableLTEP( tr_peerIo * io, tr_bool flag );
    120123
    121 tr_bool     tr_peerIoSupportsLTEP( const tr_peerIo * io );
     124static inline tr_bool tr_peerIoSupportsLTEP( const tr_peerIo * io )
     125{
     126    assert( tr_isPeerIo( io ) );
     127
     128    return io->extendedProtocolSupported;
     129}
    122130
    123131void        tr_peerIoEnableFEXT( tr_peerIo * io, tr_bool flag );
    124132
    125 tr_bool     tr_peerIoSupportsFEXT( const tr_peerIo * io );
    126 
    127 /**
    128 ***
    129 **/
    130 
    131 tr_session* tr_peerIoGetSession ( tr_peerIo * io );
     133static inline tr_bool tr_peerIoSupportsFEXT( const tr_peerIo * io )
     134{
     135    assert( tr_isPeerIo( io ) );
     136
     137    return io->fastExtensionSupported;
     138}
     139
     140/**
     141***
     142**/
     143
     144static inline tr_session* tr_peerIoGetSession ( tr_peerIo * io )
     145{
     146    assert( tr_isPeerIo( io ) );
     147    assert( io->session );
     148
     149    return io->session;
     150}
    132151
    133152const char* tr_peerIoAddrStr( const struct tr_address * addr,
    134153                              tr_port                   port );
    135154
    136 const char* tr_peerIoGetAddrStr( const tr_peerIo * io );
     155static inline const char* tr_peerIoGetAddrStr( const tr_peerIo * io )
     156{
     157    return tr_peerIoAddrStr( &io->addr, io->port );
     158}
    137159
    138160const struct tr_address * tr_peerIoGetAddress( const tr_peerIo * io,
     
    148170int                  tr_peerIoReconnect( tr_peerIo * io );
    149171
    150 tr_bool              tr_peerIoIsIncoming( const tr_peerIo * io );
     172static inline tr_bool tr_peerIoIsIncoming( const tr_peerIo * io )
     173{
     174    return io->isIncoming;
     175}
    151176
    152177static inline int    tr_peerIoGetAge( const tr_peerIo * io )
     
    163188                                          const uint8_t * peer_id );
    164189
    165 const uint8_t*       tr_peerIoGetPeersId( const tr_peerIo * io );
     190static inline const uint8_t* tr_peerIoGetPeersId( const tr_peerIo * io )
     191{
     192    assert( tr_isPeerIo( io ) );
     193    assert( io->peerIdIsSet );
     194
     195    return io->peerId;
     196}
    166197
    167198/**
     
    192223**/
    193224
    194 struct tr_crypto* tr_peerIoGetCrypto( tr_peerIo * io );
     225static inline struct tr_crypto * tr_peerIoGetCrypto( tr_peerIo * io )
     226{
     227    return io->crypto;
     228}
    195229
    196230typedef enum
     
    205239                                  int         encryptionMode );
    206240
    207 int       tr_peerIoIsEncrypted( const tr_peerIo * io );
     241static inline tr_bool tr_peerIoIsEncrypted( const tr_peerIo * io )
     242{
     243    return ( io != NULL ) && ( io->encryptionMode == PEER_ENCRYPTION_RC4 );
     244}
    208245
    209246void      tr_peerIoWriteBytes( tr_peerIo *       io,
     
    275312size_t    tr_peerIoGetWriteBufferSpace( const tr_peerIo * io );
    276313
    277 void      tr_peerIoSetBandwidth( tr_peerIo            * io,
    278                                  struct tr_bandwidth  * bandwidth );
     314static inline void tr_peerIoSetParent( tr_peerIo            * io,
     315                                       struct tr_bandwidth  * parent )
     316{
     317    assert( tr_isPeerIo( io ) );
     318
     319    tr_bandwidthSetParent( &io->bandwidth, parent );
     320}
    279321
    280322void      tr_peerIoBandwidthUsed( tr_peerIo           * io,
     
    283325                                  int                   isPieceData );
    284326
    285 tr_bool   tr_peerIoHasBandwidthLeft( const tr_peerIo  * io,
    286                                      tr_direction       dir );
     327static inline tr_bool tr_peerIoHasBandwidthLeft( const tr_peerIo  * io,
     328                                                 tr_direction       dir )
     329{
     330    assert( tr_isPeerIo( io ) );
     331
     332    return tr_bandwidthClamp( &io->bandwidth, dir, 1024 ) > 0;
     333}
     334
     335static inline double tr_peerIoGetPieceSpeed( const tr_peerIo * io, tr_direction dir )
     336{
     337    assert( tr_isPeerIo( io ) );
     338    assert( tr_isDirection( dir ) );
     339
     340    return tr_bandwidthGetPieceSpeed( &io->bandwidth, dir );
     341}
    287342
    288343/**
Note: See TracChangeset for help on using the changeset viewer.