GCGen.java 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. package com.oblivm.backend.gc.regular;
  2. import com.oblivm.backend.flexsc.Flag;
  3. import com.oblivm.backend.flexsc.Mode;
  4. import com.oblivm.backend.gc.GCGenComp;
  5. import com.oblivm.backend.gc.GCSignal;
  6. import com.oblivm.backend.network.Network;
  7. import util.Timer;
  8. public class GCGen extends GCGenComp {
  9. Garbler gb;
  10. Timer timer = null;
  11. int p;
  12. int m;
  13. public GCGen(Network channel) {
  14. super(channel, Mode.REAL);
  15. gb = new Garbler();
  16. for (int i = 0; i < 2; ++i) {
  17. labelL[i] = new GCSignal(new byte[10]);
  18. labelR[i] = new GCSignal(new byte[10]);
  19. lb[i] = new GCSignal(new byte[10]);
  20. toSend[0][i] = new GCSignal(new byte[10]);
  21. toSend[1][i] = new GCSignal(new byte[10]);
  22. }
  23. }
  24. public GCGen(Network channel, Timer timer, int p, int m) {
  25. super(channel, Mode.REAL);
  26. gb = new Garbler();
  27. for (int i = 0; i < 2; ++i) {
  28. labelL[i] = new GCSignal(new byte[10]);
  29. labelR[i] = new GCSignal(new byte[10]);
  30. lb[i] = new GCSignal(new byte[10]);
  31. toSend[0][i] = new GCSignal(new byte[10]);
  32. toSend[1][i] = new GCSignal(new byte[10]);
  33. }
  34. this.timer = timer;
  35. this.p = p;
  36. this.m = m;
  37. }
  38. private GCSignal[][] gtt = new GCSignal[2][2];
  39. private GCSignal[][] toSend = new GCSignal[2][2];
  40. private GCSignal labelL[] = new GCSignal[2];
  41. private GCSignal labelR[] = new GCSignal[2];
  42. private GCSignal[] lb = new GCSignal[2];
  43. private GCSignal garble(GCSignal a, GCSignal b) {
  44. labelL[0] = a;
  45. GCSignal.xor(R, labelL[0], labelL[1]);
  46. labelR[0] = b;
  47. GCSignal.xor(R, labelR[0], labelR[1]);
  48. int cL = a.getLSB();
  49. int cR = b.getLSB();
  50. gb.enc(labelL[cL], labelR[cR], gid, GCSignal.ZERO, lb[cL & cR]);
  51. GCSignal.xor(R, lb[cL & cR], lb[1 - (cL & cR)]);
  52. gtt[0 ^ cL][0 ^ cR] = lb[0];
  53. gtt[0 ^ cL][1 ^ cR] = lb[0];
  54. gtt[1 ^ cL][0 ^ cR] = lb[0];
  55. gtt[1 ^ cL][1 ^ cR] = lb[1];
  56. if (cL != 0 || cR != 0)
  57. gb.enc(labelL[0], labelR[0], gid, gtt[0 ^ cL][0 ^ cR], toSend[0 ^ cL][0 ^ cR]);
  58. if (cL != 0 || cR != 1)
  59. gb.enc(labelL[0], labelR[1], gid, gtt[0 ^ cL][1 ^ cR], toSend[0 ^ cL][1 ^ cR]);
  60. if (cL != 1 || cR != 0)
  61. gb.enc(labelL[1], labelR[0], gid, gtt[1 ^ cL][0 ^ cR], toSend[1 ^ cL][0 ^ cR]);
  62. if (cL != 1 || cR != 1)
  63. gb.enc(labelL[1], labelR[1], gid, gtt[1 ^ cL][1 ^ cR], toSend[1 ^ cL][1 ^ cR]);
  64. return GCSignal.newInstance(lb[0].bytes);
  65. }
  66. private void sendGTT() {
  67. try {
  68. if (timer != null)
  69. timer.start(p, m);
  70. Flag.sw.startGCIO();
  71. toSend[0][1].send(channel);
  72. toSend[1][0].send(channel);
  73. toSend[1][1].send(channel);
  74. Flag.sw.stopGCIO();
  75. if (timer != null)
  76. timer.stop(p, m);
  77. } catch (Exception e) {
  78. e.printStackTrace();
  79. System.exit(1);
  80. }
  81. }
  82. public GCSignal and(GCSignal a, GCSignal b) {
  83. Flag.sw.startGC();
  84. GCSignal res;
  85. if (a.isPublic() && b.isPublic())
  86. res = ((a.v && b.v) ? new GCSignal(true) : new GCSignal(false));
  87. else if (a.isPublic())
  88. res = a.v ? b : new GCSignal(false);
  89. else if (b.isPublic())
  90. res = b.v ? a : new GCSignal(false);
  91. else {
  92. ++numOfAnds;
  93. GCSignal ret;
  94. ret = garble(a, b);
  95. sendGTT();
  96. gid++;
  97. gatesRemain = true;
  98. res = ret;
  99. }
  100. Flag.sw.stopGC();
  101. return res;
  102. }
  103. @Override
  104. public void setEvaluate() {
  105. }
  106. }