]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
some fixes on x86
authorSage Weil <sage@newdream.net>
Fri, 1 Feb 2008 08:41:00 +0000 (00:41 -0800)
committerSage Weil <sage@newdream.net>
Fri, 1 Feb 2008 08:41:00 +0000 (00:41 -0800)
src/msg/Message.h
src/msg/SimpleMessenger.cc
src/msg/msg_types.h

index c5e7e536e347ad146501917e75b84300bfc3245e..e0398e34ebff0487fdecd1d3b7cce7f8f30971ed 100644 (file)
@@ -154,20 +154,20 @@ public:
   void set_seq(unsigned s) { env.seq = cpu_to_le64(s); }
 
   // source/dest
-  entity_inst_t& get_dest_inst() { return *(entity_inst_t*)&env.dst; }
-  void set_dest_inst(entity_inst_t& inst) { env.dst = *(ceph_entity_inst*)&inst; }
+  entity_inst_t get_dest_inst() { return entity_inst_t(env.dst); }
+  void set_dest_inst(entity_inst_t& inst) { env.dst = inst; }
 
-  entity_inst_t& get_source_inst() { return *(entity_inst_t*)&env.src; }
-  void set_source_inst(entity_inst_t& inst) { env.src = *(ceph_entity_inst*)&inst; }
+  entity_inst_t get_source_inst() { return entity_inst_t(env.src); }
+  void set_source_inst(entity_inst_t& inst) { env.src = inst; }
 
-  entity_name_t& get_dest() { return *(entity_name_t*)&env.dst.name; }
-  void set_dest(entity_name_t a) { env.dst.name = *(ceph_entity_name*)&a; }
+  entity_name_t get_dest() { return entity_name_t(env.dst.name); }
+  void set_dest(entity_name_t a) { env.dst.name = a; }
   
-  entity_name_t& get_source() { return *(entity_name_t*)&env.src.name; }
-  void set_source(entity_name_t a) { env.src.name = *(ceph_entity_name*)&a; }
+  entity_name_t get_source() { return entity_name_t(env.src.name); }
+  void set_source(entity_name_t a) { env.src.name = a; }
 
-  entity_addr_t& get_source_addr() { return *(entity_addr_t*)&env.src.addr; }
-  void set_source_addr(const entity_addr_t &i) { env.src.addr = *(ceph_entity_addr*)&i; }
+  entity_addr_t get_source_addr() { return entity_addr_t(env.src.addr); }
+  void set_source_addr(const entity_addr_t &i) { env.src.addr = i; }
 
   // virtual bits
   virtual void decode_payload() = 0;
index 0533d473f89508fa68a58dcdc73b134eff43c212..3bdf5ba87b16b57bd78eed67aec6dfb7439b8f08 100644 (file)
@@ -1447,8 +1447,8 @@ Message *Rank::Pipe::read_message()
 
   // read data
   bufferlist data;
-  int data_len = le32_to_cpu(env.data_len);
-  int data_off = le32_to_cpu(env.data_off);
+  unsigned data_len = le32_to_cpu(env.data_len);
+  unsigned data_off = le32_to_cpu(env.data_off);
   if (data_len) {
     int left = data_len;
     if (data_off & ~PAGE_MASK) {
index 0250e4454362f100d54eaff887fda9e458f66280..b5ba1d3b6d488cd3ee3ab76919b0552bff469482 100644 (file)
@@ -185,6 +185,10 @@ struct entity_inst_t {
   entity_inst_t(entity_name_t n, const entity_addr_t& a) : name(n), addr(a) {}
   entity_inst_t(const ceph_entity_inst& i) : name(i.name), addr(i.addr) { }
   entity_inst_t(const ceph_entity_name& n, const ceph_entity_addr &a) : name(n), addr(a) {}
+  operator ceph_entity_inst() {
+    ceph_entity_inst i = {name, addr};
+    return i;
+  }
 };