* Locate an existing origin or create a new one.
  * This moves the origin to front position in the commit util list.
  */
-static struct origin *get_origin(struct scoreboard *sb,
-                                struct commit *commit,
-                                const char *path)
+static struct origin *get_origin(struct commit *commit, const char *path)
 {
        struct origin *o, *l;
 
  * We have an origin -- check if the same path exists in the
  * parent and return an origin structure to represent it.
  */
-static struct origin *find_origin(struct scoreboard *sb,
-                                 struct commit *parent,
+static struct origin *find_origin(struct commit *parent,
                                  struct origin *origin)
 {
        struct origin *porigin;
 
        if (!diff_queued_diff.nr) {
                /* The path is the same as parent */
-               porigin = get_origin(sb, parent, origin->path);
+               porigin = get_origin(parent, origin->path);
                oidcpy(&porigin->blob_oid, &origin->blob_oid);
                porigin->mode = origin->mode;
        } else {
                        die("internal error in blame::find_origin (%c)",
                            p->status);
                case 'M':
-                       porigin = get_origin(sb, parent, origin->path);
+                       porigin = get_origin(parent, origin->path);
                        oidcpy(&porigin->blob_oid, &p->one->oid);
                        porigin->mode = p->one->mode;
                        break;
  * We have an origin -- find the path that corresponds to it in its
  * parent and return an origin structure to represent it.
  */
-static struct origin *find_rename(struct scoreboard *sb,
-                                 struct commit *parent,
+static struct origin *find_rename(struct commit *parent,
                                  struct origin *origin)
 {
        struct origin *porigin = NULL;
                struct diff_filepair *p = diff_queued_diff.queue[i];
                if ((p->status == 'R' || p->status == 'C') &&
                    !strcmp(p->two->path, origin->path)) {
-                       porigin = get_origin(sb, parent, p->one->path);
+                       porigin = get_origin(parent, p->one->path);
                        oidcpy(&porigin->blob_oid, &p->one->oid);
                        porigin->mode = p->one->mode;
                        break;
                                /* find_move already dealt with this path */
                                continue;
 
-                       norigin = get_origin(sb, parent, p->one->path);
+                       norigin = get_origin(parent, p->one->path);
                        oidcpy(&norigin->blob_oid, &p->one->oid);
                        norigin->mode = p->one->mode;
                        fill_origin_blob(&sb->revs->diffopt, norigin, &file_p);
         * common cases, then we look for renames in the second pass.
         */
        for (pass = 0; pass < 2 - no_whole_file_rename; pass++) {
-               struct origin *(*find)(struct scoreboard *,
-                                      struct commit *, struct origin *);
+               struct origin *(*find)(struct commit *, struct origin *);
                find = pass ? find_rename : find_origin;
 
                for (i = 0, sg = first_scapegoat(revs, commit);
                                continue;
                        if (parse_commit(p))
                                continue;
-                       porigin = find(sb, p, origin);
+                       porigin = find(p, origin);
                        if (!porigin)
                                continue;
                        if (!oidcmp(&porigin->blob_oid, &origin->blob_oid)) {
                sb.final_buf_size = o->file.size;
        }
        else {
-               o = get_origin(&sb, sb.final, path);
+               o = get_origin(sb.final, path);
                if (fill_blob_sha1_and_mode(o))
                        die(_("no such path %s in %s"), path, final_commit_name);